mirror of
https://github.com/google/nomulus.git
synced 2025-04-30 12:07:51 +02:00
Update GCB beam deployment pipeline (#134)
* Update GCB beam deployment pipeline Some of the texts are not really secerts because they are per-project. Also changed the location of the credential file to `secerts` so that in the future we may add more secerts in that folder. The encrypted file is base64 encoded, consistent with how the proxy certificates are encoded. Also made some changes to the other pipelines to facilitate automation with Spinnaker
This commit is contained in:
parent
578aefea05
commit
f20fd64537
3 changed files with 17 additions and 17 deletions
|
@ -1,17 +1,14 @@
|
||||||
# To run the build locally, install cloud-build-local first.
|
# To run the build locally, install cloud-build-local first.
|
||||||
# Then run:
|
# Then run:
|
||||||
# cloud-build-local --config=cloudbuild-deploy-beam.yaml --dryrun=false \
|
# cloud-build-local --config=cloudbuild-deploy-beam.yaml --dryrun=false \
|
||||||
# --substitutions=TAG_NAME=[TAG],_CREDENTIAL_JSON=[CREDENTIAL_JSON],\
|
# --substitutions=TAG_NAME=[TAG],_ENV=[ENV] ..
|
||||||
# _CREDENTIAL_KEYRING=[CREDENTIAL_KEYRING],_CREDENTIAL_KEY=[CREDENTIAL_KEY],\
|
|
||||||
# _ENV=[ENV] ..
|
|
||||||
#
|
#
|
||||||
# This will deploy Beam pipelines to GCS for the PROJECT_ID defined in gcloud
|
# This will deploy Beam pipelines to GCS for the PROJECT_ID defined in gcloud
|
||||||
# tool.
|
# tool.
|
||||||
#
|
#
|
||||||
# To manually trigger a build on GCB, run:
|
# To manually trigger a build on GCB, run:
|
||||||
# gcloud builds submit --config=cloudbuild-deploy-beam.yaml --substitutions=TAG_NAME=[TAG],\
|
# gcloud builds submit --config=cloudbuild-deploy-beam.yaml \
|
||||||
# _CREDENTIAL_JSON=[CREDENTIAL_JSON],_CREDENTIAL_KEYRING=[CREDENTIAL_KEYRING],\
|
# --substitutions=TAG_NAME=[TAG],_ENV=[ENV] ..
|
||||||
# _CREDENTIAL_KEY=[CREDENTIAL_KEY],_ENV=[ENV] ..
|
|
||||||
#
|
#
|
||||||
# To trigger a build automatically, follow the instructions below and add a trigger:
|
# To trigger a build automatically, follow the instructions below and add a trigger:
|
||||||
# https://cloud.google.com/cloud-build/docs/running-builds/automate-builds
|
# https://cloud.google.com/cloud-build/docs/running-builds/automate-builds
|
||||||
|
@ -28,27 +25,26 @@ steps:
|
||||||
args:
|
args:
|
||||||
- gsutil
|
- gsutil
|
||||||
- cp
|
- cp
|
||||||
- gs://${PROJECT_ID}-deploy/nomulus-credential/${_CREDENTIAL_JSON}
|
- gs://${PROJECT_ID}-deploy/secrets/tool-credential.json.enc
|
||||||
- .
|
- .
|
||||||
# Decrypt the credential
|
# Decrypt the credential
|
||||||
- name: 'gcr.io/cloud-builders/gcloud'
|
- name: 'gcr.io/${PROJECT_ID}/builder:latest'
|
||||||
|
entrypoint: /bin/bash
|
||||||
args:
|
args:
|
||||||
- kms
|
- -c
|
||||||
- decrypt
|
- |
|
||||||
- --ciphertext-file=${_CREDENTIAL_JSON}
|
cat tool-credential.json.enc | base64 -d | gcloud kms decrypt \
|
||||||
- --plaintext-file=nomulus-credential.json
|
--ciphertext-file=- --plaintext-file=tool-credential.json \
|
||||||
- --location=global
|
--location=global --keyring=nomulus-tool-keyring --key=nomulus-tool-key
|
||||||
- --keyring=${_CREDENTIAL_KEYRING}
|
|
||||||
- --key=${_CREDENTIAL_KEY}
|
|
||||||
# Deploy spec11 and invoicing pipeline to GCS
|
# Deploy spec11 and invoicing pipeline to GCS
|
||||||
- name: 'gcr.io/${PROJECT_ID}/builder:latest'
|
- name: 'gcr.io/${PROJECT_ID}/builder:latest'
|
||||||
entrypoint: /bin/bash
|
entrypoint: /bin/bash
|
||||||
args:
|
args:
|
||||||
- -c
|
- -c
|
||||||
- |
|
- |
|
||||||
java -jar nomulus.jar -e ${_ENV} --credential nomulus-credential.json \
|
java -jar nomulus.jar -e ${_ENV} --credential tool-credential.json \
|
||||||
deploy_spec11_pipeline
|
deploy_spec11_pipeline
|
||||||
java -jar nomulus.jar -e ${_ENV} --credential nomulus-credential.json \
|
java -jar nomulus.jar -e ${_ENV} --credential tool-credential.json \
|
||||||
deploy_invoicing_pipeline
|
deploy_invoicing_pipeline
|
||||||
timeout: 3600s
|
timeout: 3600s
|
||||||
options:
|
options:
|
|
@ -45,6 +45,7 @@ artifacts:
|
||||||
- 'output/*.tar'
|
- 'output/*.tar'
|
||||||
- 'output/nomulus.jar'
|
- 'output/nomulus.jar'
|
||||||
- 'release/cloudbuild-sync.yaml'
|
- 'release/cloudbuild-sync.yaml'
|
||||||
|
- 'release/cloudbuild-beam.yaml'
|
||||||
timeout: 3600s
|
timeout: 3600s
|
||||||
options:
|
options:
|
||||||
machineType: 'N1_HIGHCPU_8'
|
machineType: 'N1_HIGHCPU_8'
|
||||||
|
|
|
@ -75,8 +75,11 @@ steps:
|
||||||
sed -i s%distroless/java%${PROJECT_ID}/base@$base_digest% proxy/Dockerfile
|
sed -i s%distroless/java%${PROJECT_ID}/base@$base_digest% proxy/Dockerfile
|
||||||
sed -i s/builder:latest/builder@$builder_digest/g release/cloudbuild-proxy.yaml
|
sed -i s/builder:latest/builder@$builder_digest/g release/cloudbuild-proxy.yaml
|
||||||
sed -i s/builder:latest/builder@$builder_digest/g release/cloudbuild-nomulus.yaml
|
sed -i s/builder:latest/builder@$builder_digest/g release/cloudbuild-nomulus.yaml
|
||||||
|
sed -i s/builder:latest/builder@$builder_digest/g release/cloudbuild-beam.yaml
|
||||||
sed -i s/GCP_PROJECT/${PROJECT_ID}/ proxy/kubernetes/proxy-*.yaml
|
sed -i s/GCP_PROJECT/${PROJECT_ID}/ proxy/kubernetes/proxy-*.yaml
|
||||||
sed -i s/'$${TAG_NAME}'/${TAG_NAME}/g release/cloudbuild-sync.yaml
|
sed -i s/'$${TAG_NAME}'/${TAG_NAME}/g release/cloudbuild-sync.yaml
|
||||||
|
sed -i s/'$${TAG_NAME}'/${TAG_NAME}/g release/cloudbuild-beam.yaml
|
||||||
|
sed -i s/'$${_ENV}'/production/g release/cloudbuild-beam.yaml
|
||||||
# Upload the gradle binary to GCS if it does not exist and point URL in gradle wrapper to it.
|
# Upload the gradle binary to GCS if it does not exist and point URL in gradle wrapper to it.
|
||||||
- name: 'gcr.io/cloud-builders/gsutil'
|
- name: 'gcr.io/cloud-builders/gsutil'
|
||||||
entrypoint: /bin/bash
|
entrypoint: /bin/bash
|
||||||
|
|
Loading…
Add table
Reference in a new issue