Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

ci: change s3 cache provider to optimize costs #2344

Merged
merged 53 commits into from
Nov 26, 2024
Merged
Show file tree
Hide file tree
Changes from 49 commits
Commits
Show all changes
53 commits
Select commit Hold shift + click to select a range
eaf429c
ci: change s3 backend to decrease costs in tests-rs-package
lklimek Nov 20, 2024
69be7f6
test: comment out some tests to speed up testing - to be reverted
lklimek Nov 21, 2024
18fe6ab
chore: rename S3 vars to CACHE_*
lklimek Nov 21, 2024
e5090b5
ci: fix region
lklimek Nov 21, 2024
edb98c1
chore: sccache action
lklimek Nov 21, 2024
4edf309
chore: s/env/vars
lklimek Nov 21, 2024
3aa361c
chore: env/vars
lklimek Nov 21, 2024
524b901
chore: minor fixes
lklimek Nov 21, 2024
dbacec6
chore: dockerfile typo
lklimek Nov 21, 2024
c6ed038
chore: some secrets fixes
lklimek Nov 21, 2024
b3200a4
build: dockerfile improvements
lklimek Nov 21, 2024
9d3f8e5
chore: remove aws-actions/configure-aws-credentials@v4
lklimek Nov 21, 2024
3337f59
chore: change how we configure ecr credentials
lklimek Nov 21, 2024
275fac1
chore: add some debug, to be reverted
lklimek Nov 21, 2024
7d3a679
ci: rs-crates-security sccache
lklimek Nov 21, 2024
73fb938
chore: typo
lklimek Nov 21, 2024
4dbff39
chore: debug sccache in gha
lklimek Nov 21, 2024
6e8b28d
chore: fix keys
lklimek Nov 21, 2024
c3a7e5d
chore: testing
lklimek Nov 21, 2024
e77787e
chore: sccache input rename
lklimek Nov 22, 2024
9c524d2
chore: fix layers push
lklimek Nov 22, 2024
e899b18
chore: fix
lklimek Nov 22, 2024
edb040c
chore: typo
lklimek Nov 22, 2024
806225f
build: Dockerfile cargo incremental
lklimek Nov 22, 2024
12fe70b
refactor(docker): some renames
lklimek Nov 25, 2024
a42f95d
chore: try to unset credentials
lklimek Nov 25, 2024
517a83f
chore: unset aws creds
lklimek Nov 25, 2024
a470e8e
chore: unset aws creds, continued
lklimek Nov 25, 2024
e6b4de8
chore: unset creds moved to docker
lklimek Nov 25, 2024
4046a2f
chore: update all other files
lklimek Nov 25, 2024
88c2f0a
Revert "test: comment out some tests to speed up testing - to be reve…
lklimek Nov 25, 2024
aeb7cb3
chore: remove deprecated set-output
lklimek Nov 25, 2024
9486d0f
chore: comment out aws creds from "Build JS" step
lklimek Nov 25, 2024
358c2c1
Merge remote-tracking branch 'origin/v1.6-dev' into ci/change-s3
lklimek Nov 25, 2024
bf4bb7a
fix: invalid region
lklimek Nov 25, 2024
e007e83
chore: remove environment
lklimek Nov 25, 2024
601c907
chore: remove test code
lklimek Nov 25, 2024
2893ac0
chore: trigger full workflow run
lklimek Nov 25, 2024
4148f7c
chore: trigger rebuild
lklimek Nov 25, 2024
5f3eb51
chore: rabbit's feedback
lklimek Nov 25, 2024
2fa40cd
chore: apply rabbit feedback
lklimek Nov 25, 2024
9a0a8ce
chore: cleanup ECR login logic
lklimek Nov 25, 2024
ecc7396
chore: minor fixes from rabbit
lklimek Nov 25, 2024
0928f49
Merge branch 'v1.6-dev' into ci/change-s3
lklimek Nov 25, 2024
f7ffa9a
fix: multi-platform docker build cache misses due to overwriting othe…
lklimek Nov 25, 2024
e8bb748
chore: further platform fixes
lklimek Nov 25, 2024
646c830
fix: use the same sccache prefix in gha and docker
lklimek Nov 25, 2024
f33c8c7
chore: double-check dockerfile secrets mounts
lklimek Nov 26, 2024
ba6507a
refactor: improve readability of aws creds
lklimek Nov 26, 2024
d100822
chore: use clang
lklimek Nov 26, 2024
5fbe581
chore: layert cache profile fix
lklimek Nov 26, 2024
6c1bb7a
chore: fix docker
lklimek Nov 26, 2024
b910256
chore: fix quotes
lklimek Nov 26, 2024
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
43 changes: 43 additions & 0 deletions .github/actions/aws_credentials/action.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,43 @@
---
# This file contains configuration of aws credentials file.
# Its primary use is to prepare a credentials file that will be used as a secrets mount when building Docker images.
name: "aws_credentials"
description: "Configure .aws/credentials"
inputs:
access_key_id:
description: Access key ID
required: true
secret_access_key:
description: Secret access key
required: true
profile:
description: AWS profile to use
default: "default"

lklimek marked this conversation as resolved.
Show resolved Hide resolved
runs:
using: composite
steps:
- name: Configure AWS credentials
shell: bash
run: |
mkdir -p "${HOME}/.aws"
cat >> ${HOME}/.aws/credentials << EOF
[${{ inputs.profile }}]
aws_access_key_id=${{ inputs.access_key_id }}
aws_secret_access_key=${{ inputs.secret_access_key }}
EOF
chmod -R go-rwx ${HOME}/.aws
lklimek marked this conversation as resolved.
Show resolved Hide resolved

- name: Set env variables
shell: bash
run: |
# Exit on any error
set -euo pipefail
# Validate AWS_PROFILE is not empty
if [ -z "${{ inputs.profile }}" ]; then
echo "Error: AWS_PROFILE cannot be empty"
exit 1
fi
# Export variables
echo "AWS_PROFILE=${{ inputs.profile }}" >> $GITHUB_ENV
echo "AWS_SHARED_CREDENTIALS_FILE=${HOME}/.aws/credentials" >> $GITHUB_ENV
lklimek marked this conversation as resolved.
Show resolved Hide resolved
42 changes: 42 additions & 0 deletions .github/actions/aws_ecr_login/action.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,42 @@
---
# Login to AWS ECR
name: "aws_ecr_login"
description: "Login to AWS ECR to store Docker containers"
inputs:
aws_account_id:
description: AWS account ID (AWS_ACCOUNT_ID)
required: true
aws_access_key_id:
description: Access key ID (AWS_ACCESS_KEY_ID)
required: true
aws_secret_access_key:
description: Secret access key (AWS_SECRET_ACCESS_KEY)
required: true
aws_region:
description: AWS region to use (AWS_REGION)
required: true

runs:
using: composite
steps:
- name: Configure AWS credentials and bucket region
uses: aws-actions/configure-aws-credentials@v4
with:
aws-access-key-id: ${{ inputs.aws_access_key_id }}
aws-secret-access-key: ${{ inputs.aws_secret_access_key }}
aws-region: ${{ inputs.aws_region }}

- name: Login to ECR
run: |
aws ecr get-login-password \
--region ${{ inputs.aws_region }} | docker login --username AWS --password-stdin ${{ inputs.aws_account_id }}.dkr.ecr.${{ inputs.aws_region }}.amazonaws.com
shell: bash

# Unset AWS credentials to avoid conflicts, as we prefer credentials from ~/.aws/credentials to authenticate
- name: Unset AWS credentials to avoid conflicts
shell: bash
run: |
echo AWS_DEFAULT_REGION='' >> $GITHUB_ENV
echo AWS_REGION='' >> $GITHUB_ENV
echo AWS_ACCESS_KEY_ID='' >> $GITHUB_ENV
echo AWS_SECRET_ACCESS_KEY='' >> $GITHUB_ENV
57 changes: 36 additions & 21 deletions .github/actions/docker/action.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -25,21 +25,24 @@ inputs:
cargo_profile:
description: Cargo build profile, i.e release or dev
default: dev
bucket:
description: S3 bucket to use for caching, must match runner define in `runs-on`
default: multi-runner-cache-x1xibo9c
region:
cache_bucket:
shumkov marked this conversation as resolved.
Show resolved Hide resolved
description: S3 bucket to use for caching (both sccache and layer cache)
required: true
cache_region:
description: S3 bucket region
required: true
aws_access_key_id:
description: AWS access key ID
cache_endpoint:
shumkov marked this conversation as resolved.
Show resolved Hide resolved
description: S3 endpoint to use for caching
required: true
cache_access_key_id:
description: Access key ID for s3 cache
required: true
aws_secret_access_key:
description: AWS secret access key
cache_secret_access_key:
description: Secret access key for s3 cache
required: true
cache_to_name:
description: 'Save cache to name manifest (should be used only on default branch)'
default: 'false'
description: "Save cache to name manifest (should be used only on default branch)"
default: "false"
outputs:
digest:
value: ${{ steps.docker_build.outputs.digest }}
Expand Down Expand Up @@ -80,9 +83,13 @@ runs:
id: layer_cache_settings
with:
name: ${{ inputs.image_name }}
region: ${{ inputs.region }}
bucket: ${{ inputs.bucket }}
region: ${{ inputs.cache_region }}
bucket: ${{ inputs.cache_bucket }}
endpoint: ${{ inputs.cache_endpoint }}
prefix: "cache-layers/${{ inputs.platform }}/"
cache_to_name: ${{ inputs.cache_to_name }}
s3_access_key_id: ${{ inputs.cache_access_key_id }}
s3_secret_access_key: ${{ inputs.cache_secret_access_key }}

- name: Set HOME variable to github context
shell: bash
Expand Down Expand Up @@ -133,7 +140,7 @@ runs:
id: arch
uses: actions/github-script@v6
with:
result-encoding: 'string'
result-encoding: "string"
script: return '${{ inputs.platform }}'.replace('linux/', '');

- name: Inject cargo cache into docker
Expand All @@ -148,9 +155,22 @@ runs:
}
skip-extraction: ${{ steps.yarn-cache.outputs.cache-hit }}

- name: Configure sccache settings
uses: ./.github/actions/sccache
id: sccache
with:
bucket: ${{ inputs.cache_bucket }}
region: ${{ inputs.cache_region }}
endpoint: ${{ inputs.cache_endpoint }}
access_key_id: ${{ inputs.cache_access_key_id }}
secret_access_key: ${{ inputs.cache_secret_access_key }}
platform: ${{ inputs.platform }}
install: false

- name: Build and push Docker image ${{ inputs.image }}
id: docker_build
uses: docker/build-push-action@v6
env: ${{ steps.layer_cache_settings.outputs.env_vars }}
with:
context: .
builder: ${{ steps.buildx.outputs.name }}
Expand All @@ -159,14 +179,9 @@ runs:
push: ${{ inputs.push_tags }}
tags: ${{ inputs.push_tags == 'true' && steps.docker_meta.outputs.tags || '' }}
platforms: ${{ inputs.platform }}
build-args: |
CARGO_BUILD_PROFILE=${{ inputs.cargo_profile }}
RUSTC_WRAPPER=sccache
SCCACHE_BUCKET=${{ inputs.bucket }}
SCCACHE_REGION=${{ inputs.region }}
SCCACHE_S3_KEY_PREFIX=${{ runner.os }}/sccache
AWS_ACCESS_KEY_ID=${{ inputs.aws_access_key_id }}
AWS_SECRET_ACCESS_KEY=${{ inputs.aws_secret_access_key }}
secret-files: |
AWS=${{ env.HOME }}/.aws/credentials
build-args: ${{ steps.sccache.outputs.env_vars }}
cache-from: ${{ steps.layer_cache_settings.outputs.cache_from }}
cache-to: ${{ steps.layer_cache_settings.outputs.cache_to }}
outputs: type=image,name=${{ inputs.image_org }}/${{ inputs.image_name }},push-by-digest=${{ inputs.push_tags != 'true' }},name-canonical=true,push=true
4 changes: 0 additions & 4 deletions .github/actions/librocksdb/action.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -9,10 +9,6 @@ inputs:
description: RocksDB version, eg. "8.10.2"
required: false
default: "8.10.2"
bucket:
description: S3 bucket to use for caching
required: false
default: multi-runner-cache-x1xibo9c
force:
description: Force rebuild
required: false
Expand Down
8 changes: 1 addition & 7 deletions .github/actions/rust/action.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -31,7 +31,7 @@ runs:
fi

echo "TOOLCHAIN_VERSION=$TOOLCHAIN_VERSION" >> $GITHUB_ENV
echo "::set-output name=version::$TOOLCHAIN_VERSION"
echo "version=$TOOLCHAIN_VERSION" >> $GITHUB_OUTPUT

- uses: dtolnay/rust-toolchain@master
name: Install Rust toolchain
Expand Down Expand Up @@ -82,12 +82,6 @@ runs:
echo "PROTOC=${HOME}/.local/bin/protoc" >> $GITHUB_ENV
export PATH="${PATH}:${HOME}/.local/bin"

- name: Install sccache-cache
uses: mozilla-actions/[email protected]
with:
version: "v0.8.2" # Must be the same as in Dockerfile
if: inputs.cache == 'true'

- name: Set HOME variable to github context
shell: bash
run: echo "HOME=$HOME" >> $GITHUB_ENV
Expand Down
40 changes: 31 additions & 9 deletions .github/actions/s3-layer-cache-settings/action.yaml
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
name: 'Get S3 Docker Layer Cache settings'
name: "Get S3 Docker Layer Cache settings"
description: |
This action generates string with s3-based cache configuration for docker buildx.
It defines three manifests:
Expand All @@ -8,38 +8,59 @@ description: |

inputs:
name:
description: 'Cache key name will be used as a prefix for all docker image manifests'
description: "Cache key name will be used as a prefix for all docker image manifests"
required: true
head_ref:
description: 'Head ref for an additional manifest to hit all builds for this head'
description: "Head ref for an additional manifest to hit all builds for this head"
default: ${{ github.ref }}
region:
description: S3 region
required: true
bucket:
description: S3 bucket name
required: true
endpoint:
description: S3 endpoint to use for caching
required: false
prefix:
description: S3 key prefix
default: 'cache-layers/'
default: "cache-layers/"
s3_access_key_id:
description: Access key ID for S3 cache
required: true
s3_secret_access_key:
description: Secret access key for S3 cache
required: true
mode:
description: Cache mode
default: max
cache_to_name:
description: 'Save cache to name manifest (should be used only on default branch)'
default: 'false'
description: "Save cache to name manifest (should be used only on default branch)"
default: "false"

outputs:
cache_to:
description: 'String with s3-based cache configuration for docker buildx cache-to option'
description: "String with s3-based cache configuration for docker buildx cache-to option"
value: ${{ steps.script.outputs.cache_to }}
cache_from:
description: 'String with s3-based cache configuration for docker buildx cache-from option'
description: "String with s3-based cache configuration for docker buildx cache-from option"
value: ${{ steps.script.outputs.cache_from }}
env_vars:
description: "Environment variables to set before running docker buildx"
value: |
AWS_PROFILE=docker-layers
AWS_SHARED_CREDENTIALS_FILE=${HOME}/.aws/credentials

runs:
using: composite
steps:
- name: Configure AWS credentials for s3 layers
uses: ./.github/actions/aws_credentials
with:
access_key_id: ${{ inputs.access_key_id }}
secret_access_key: ${{ inputs.secret_access_key }}
profile: "docker-layers"

- uses: actions/github-script@v6
lklimek marked this conversation as resolved.
Show resolved Hide resolved
id: script
with:
Expand All @@ -49,6 +70,7 @@ runs:
region: '${{ inputs.region }}',
bucket: '${{ inputs.bucket }}',
prefix: '${{ inputs.prefix }}',
endpoint_url: '${{ inputs.endpoint }}',
};
lklimek marked this conversation as resolved.
Show resolved Hide resolved

const settingsString = Object.entries(settings)
Expand All @@ -59,7 +81,7 @@ runs:
const sanitizedHeadRef = '${{ inputs.head_ref }}'.replace(/[^a-zA-Z0-9]/g, '-');

const shaManifestName = '${{ inputs.name }}_sha_${{ github.sha }}';
const headRefManifestName = '${{ inputs.name }}_tag_${ sanitizedHeadRef }';
const headRefManifestName = '${{ inputs.name }}_tag_' + sanitizedHeadRef;

const cacheFromManifestNames = [
shaManifestName,
Expand Down
75 changes: 75 additions & 0 deletions .github/actions/sccache/action.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,75 @@
---
name: "sccache"
description: "Configure sccache caching"
inputs:
bucket:
description: S3 bucket to use for caching
required: true
region:
description: S3 bucket region
required: true
endpoint:
description: S3 endpoint to use for caching
required: true
access_key_id:
description: S3 endpoint access key ID
required: true
secret_access_key:
description: S3 endpoint secret access key
required: true
platform:
description: "Platform and architecture to use when caching; defaults to linux/amd64"
required: false
default: "linux/amd64"
install:
description: "Install sccache"
default: "true"
version:
description: "sccache version"
default: "0.8.2"
required: false
outputs:
env_vars:
description: "Environment variables to set"
value: |
AWS_PROFILE=sccache
CARGO_INCREMENTAL=0
RUSTC_WRAPPER=sccache
SCCACHE_BUCKET=${{ inputs.bucket }}
SCCACHE_REGION=${{ inputs.region }}
SCCACHE_ENDPOINT=${{ inputs.endpoint }}
SCCACHE_S3_KEY_PREFIX=sccache/${{ inputs.platform }}/
SCCACHE_VERSION=${{ inputs.version }}
CC="sccache cc"
CXX="sccache c++"

lklimek marked this conversation as resolved.
Show resolved Hide resolved
# TODO: Cache deps here to save 1 minute
runs:
using: composite
steps:
- name: Install sccache binary
if: ${{ inputs.install == 'true' }}
uses: mozilla-actions/[email protected]
with:
version: "v${{ inputs.version }}"

- name: Configure AWS credentials
uses: ./.github/actions/aws_credentials
with:
access_key_id: ${{ inputs.access_key_id }}
secret_access_key: ${{ inputs.secret_access_key }}
profile: "sccache"

- name: Configure sccache
shell: bash
run: |
echo "CARGO_INCREMENTAL=0" >> $GITHUB_ENV
echo "RUSTC_WRAPPER=sccache" >> $GITHUB_ENV
echo "SCCACHE_BUCKET=${{ inputs.bucket }}" >> $GITHUB_ENV
echo "SCCACHE_REGION=${{ inputs.region }}" >> $GITHUB_ENV
echo "SCCACHE_ENDPOINT=${{ inputs.endpoint }}" >> $GITHUB_ENV
echo "SCCACHE_S3_KEY_PREFIX=sccache/${{ inputs.platform }}/" >> $GITHUB_ENV
# "SCCACHE_VERSION" is used inside Docker to install the same version of sccache
echo "SCCACHE_VERSION=${{ inputs.version }}" >> $GITHUB_ENV
lklimek marked this conversation as resolved.
Show resolved Hide resolved
echo "CC=\"sccache cc\"" >> $GITHUB_ENV
echo "CXX=\"sccache c++\"" >> $GITHUB_ENV
Loading
Loading