From e0ac1b5af9b30ec1a9ae81da922925987987f398 Mon Sep 17 00:00:00 2001 From: Kai Lueke Date: Wed, 24 Apr 2024 16:52:11 +0900 Subject: [PATCH] Migrate release AMI gc to ci-automation The deletion of old release AMIs was still relying on the previous Jenkins setup. Move this to the ci-automation folder. --- ci-automation/garbage_collect.sh | 1 + ci-automation/garbage_collect_cloud.sh | 15 +++++++++++++++ jenkins/README.md | 12 +----------- 3 files changed, 17 insertions(+), 11 deletions(-) diff --git a/ci-automation/garbage_collect.sh b/ci-automation/garbage_collect.sh index a84e24c2016..90e1df66013 100644 --- a/ci-automation/garbage_collect.sh +++ b/ci-automation/garbage_collect.sh @@ -256,6 +256,7 @@ function _garbage_collect_impl() { docker run --pull always --rm --net host \ --env AZURE_AUTH_CREDENTIALS --env AZURE_PROFILE \ --env AWS_ACCESS_KEY_ID --env AWS_SECRET_ACCESS_KEY \ + --env AWS_CREDENTIALS \ --env DIGITALOCEAN_TOKEN_JSON \ --env EQUINIXMETAL_KEY --env EQUINIXMETAL_PROJECT \ --env GCP_JSON_KEY \ diff --git a/ci-automation/garbage_collect_cloud.sh b/ci-automation/garbage_collect_cloud.sh index 9b36de41c6d..8c038399aa9 100755 --- a/ci-automation/garbage_collect_cloud.sh +++ b/ci-automation/garbage_collect_cloud.sh @@ -1,5 +1,6 @@ #!/bin/bash set -euo pipefail +source ci-automation/ci_automation_common.sh timeout --signal=SIGQUIT 60m ore aws gc --access-id "${AWS_ACCESS_KEY_ID}" --secret-key "${AWS_SECRET_ACCESS_KEY}" timeout --signal=SIGQUIT 60m ore do gc --config-file=<(echo "${DIGITALOCEAN_TOKEN_JSON}" | base64 --decode) timeout --signal=SIGQUIT 60m ore gcloud gc --json-key <(echo "${GCP_JSON_KEY}" | base64 --decode) @@ -10,3 +11,17 @@ timeout --signal=SIGQUIT 60m ore openstack gc --duration 6h \ --config-file=<(echo "${OPENSTACK_CREDS}" | base64 --decode) timeout --signal=SIGQUIT 60m ore brightbox gc --duration 6h \ --brightbox-client-id="${BRIGHTBOX_CLIENT_ID}" --brightbox-client-secret="${BRIGHTBOX_CLIENT_SECRET}" +secret_to_file aws_credentials_config_file "${AWS_CREDENTIALS}" +for channel in alpha beta stable lts; do + for arch in amd64 arm64; do + timeout --signal=SIGQUIT 240m plume prune --days 365 \ + --keep-last 2 \ + --days-soft-deleted 21 \ + --check-last-launched \ + --days-last-launched 60 \ + --verbose \ + --board="${arch}-usr" \ + --channel="${channel}" \ + --aws-credentials="${aws_credentials_config_file}" + done +done diff --git a/jenkins/README.md b/jenkins/README.md index aed78ce79af..827d4706fe7 100644 --- a/jenkins/README.md +++ b/jenkins/README.md @@ -1,11 +1 @@ -The scripts in this directory are run from [OS Jenkins jobs][jenkins-os]. By -storing the Jenkins scripts in this repository, they are more tightly coupled -to the release branch of the SDK scripts that they require. The Jenkins jobs -are responsible for setting up the environment and securely initializing an SDK -in the workspace before running these scripts. - -The special files named `formats-${BOARD}.txt` are space-separated lists of VM -image formats that should be built for releases on this branch; i.e. the script -`vm.sh` is run for each item in the list. - -[jenkins-os]: https://github.com/coreos/jenkins-os +This folder is unused.