Esta página explica como se conectar a um repositório do servidor Bitbucket para o Cloud Build.
Antes de começar
-
Enable the Cloud Build, Secret Manager, and Compute Engine APIs.
- Siga as instruções para conectar um host do Bitbucket Server antes de conectar repositórios.
Como se conectar a um repositório do Bitbucket Server
Console
Para conectar um repositório do Bitbucket Server ao Cloud Build usando o console do Google Cloud:
Abra a página Repositórios no console do Google Cloud.
Na parte de cima da página, selecione a guia 1ª geração.
Clique em Conectar repositório.
Selecione Bitbucket Server.
O painel Conectar repositório vai aparecer. Preencha o seguinte etapas para conectar o repositório do Bitbucket Server:
Região: selecione uma região em que a conexão está.
Em Selecionar provedor de gerenciamento de código-fonte, selecione Bitbucket Server.
Conexão de host: selecione o nome da conexão de host no menu suspenso.
Clique em Continuar.
Em Selecionar repositório, selecione os repositórios do Bitbucket Server. que você quer conectar ao Cloud Build.
Depois de selecionar sua conta e os repositórios do Bitbucket Server, leia a exoneração de responsabilidade de consentimento e marque a caixa de seleção ao lado para indicar que você aceita os termos apresentados.
Clique em Conectar para conectar seus repositórios.
Quando um repositório é conectado, o Cloud Build configura um webhook no repositório na sua instância do Bitbucket Server. O repositório envia webhooks para invocar os gatilhos do Bitbucket Server correspondentes quando você faz alterações no repositório. Um repositório de dados também pode ser conectado a vários vezes com várias conexões de host. Para saber como gerenciar webhooks, consulte Gerenciar webhooks.
Para localizar o webhook, você precisa do ID dele. O ID do webhook para cada repositório conectado pode ser encontrado no
BitbucketServerConfig
.Digite o seguinte comando para recuperar o ID do webhook:
gcloud alpha builds enterprise-config bitbucketserver describe CONFIG_NAME --region=REGION
Em que:
- CONFIG_NAME é o nome da configuração do Bitbucket Server.
- REGION é a região da conexão do host do Bitbucket Server
Clique em Concluído. Se preferir, clique em Criar um acionador.
API
Para conectar seu repositório do Bitbucket Server ao Cloud Build usando a API, siga estas etapas:
Use o modelo JSON abaixo para conectar seu repositório:
{ "parent": "projects/PROJECT_NUMBER/locations/REGION/bitbucketServerConfigs/BITBUCKET_SERVER_CONFIG_NAME", "requests": { "parent": "projects/PROJECT_NUMBER/locations/REGION/bitbucketServerConfigs/BITBUCKET_SERVER_CONFIG_NAME", "bitbucketServerConnectedRepository": { "parent": "projects/PROJECT_NUMBER/locations/REGION/bitbucketServerConfigs/BITBUCKET_SERVER_CONFIG_NAME", "repo": { "projectKey": "PROJECT_KEY", "repoSlug": "REPO_SLUG" } } } }
Em que:
- PROJECT_NUMBER é o número do projeto do Cloud.
- REGION é a região associada à configuração do Bitbucket Server.
- BITBUCKET_SERVER_CONFIG_NAME é o nome da configuração do Bitbucket Server.
- PROJECT_KEY é a chave do seu projeto do Bitbucket Server.
Para conectar um repositório pessoal, a chave do projeto precisa
conter o til (
~
) antes do nome de usuário. Por exemplo,~${USERNAME}
. O URL completo de um repositório de host pode ser parecido comhttps://${HOST_URI}/projects/~${USER_NAME}/repos/${REPO_SLUG}
. - REPO_SLUG é o slug do repositório do Bitbucket Server.
Digite o seguinte comando
curl
no seu terminal:curl -X POST -H "Authorization: Bearer "$(gcloud auth print-access-token) -H "Content-Type: application/json; charset=utf-8" -H "x-goog-user-project: PROJECT_NUMBER" https://cloudbuild.googleapis.com/v1/projects/PROJECT_ID/locations/REGION/bitbucketServerConfigs/BITBUCKET_SERVER_CONFIG_NAME/connectedRepositories:batchCreate -d @requests.json
Em que:
- PROJECT_NUMBER é o número do projeto do Cloud.
- PROJECT_ID é seu ID do projeto do Cloud.
- REGION é a região associada à configuração do Bitbucket Server.
- BITBUCKET_SERVER_CONFIG_NAME é o nome da configuração do Bitbucket Server.
Se a solicitação for bem-sucedida, o corpo da resposta incluirá uma instância de Operation.
Digite o seguinte comando
curl
no seu terminal:curl -X GET -H "Authorization: Bearer "$(gcloud auth print-access-token) -H "Content-Type: application/json; charset=utf-8" -H "x-goog-user-project: PROJECT_NUMBER" https://cloudbuild.googleapis.com/v1/projects/PROJECT_ID/locations/REGION/operations/OPERATION_ID
Em que:
- PROJECT_NUMBER é o número do projeto do Cloud.
- PROJECT_ID é seu ID do projeto do Cloud.
- REGION é a região associada à configuração do Bitbucket Server.
- OPERATION_ID é o ID da operação de criação da configuração do Bitbucket Server.
O ID da operação pode ser encontrado no campo
name
da resposta. O formato do camponame
na sua resposta será assim:projects/project-id/locations/region/operations/operation-id
.
Talvez seja necessário continuar executando o comando da API
GetOperation
até que a resposta contenhadone: true
, o que indica que a operação foi concluída. Se o repositório do Bitbucket Server estiver conectado corretamente, você verá o repositório conectado no camporesponse.bitbucketServerConnectedRepositories
. Caso contrário, consulte o campoerror
para conferir um relatório de erro detalhado.
A seguir
- Saiba como criar repositórios do Bitbucket Server.
- Saiba como criar repositórios do Bitbucket Server em uma rede privada.
- Saiba como realizar implantações azul-verde no Compute Engine.