From 5b73485befb29a4c5c6a3f6885bc77dbac8d7e20 Mon Sep 17 00:00:00 2001 From: Jackson Newhouse Date: Mon, 13 Jan 2025 11:14:47 -0800 Subject: [PATCH] feat: rework when docker builds and have main builds use release profile. (#25826) --- .circleci/config.yml | 47 ++++++++++++++++++++++---------------------- Dockerfile | 2 +- 2 files changed, 25 insertions(+), 24 deletions(-) diff --git a/.circleci/config.yml b/.circleci/config.yml index bc0db837f79..0e8681d2275 100644 --- a/.circleci/config.yml +++ b/.circleci/config.yml @@ -67,6 +67,13 @@ nofork_filter: &nofork_filter branches: ignore: /pull\/[0-9]+/ +docker_filter: &docker_filter + filters: + branches: + only: + - main + - /.*docker.*/ + commands: rust_components: description: Verify installed components @@ -447,9 +454,6 @@ jobs: type: string resource_class: type: string - profile: - type: string - default: release image_name: type: string default: influxdb3-core @@ -458,6 +462,14 @@ jobs: resource_class: << parameters.resource_class >> steps: - checkout + - run: + name: "Set Cargo profile based on branch" + command: | + if [ "$CIRCLE_BRANCH" = "main" ]; then + echo "export DOCKER_PROFILE=release" >> "$BASH_ENV" + else + echo "export DOCKER_PROFILE=quick-release" >> "$BASH_ENV" + fi - run: name: Build the docker image command: | @@ -466,7 +478,7 @@ jobs: "aws,gcp,azure,jemalloc_replacing_malloc,tokio_console,system-py" \ "<< parameters.image_name >>:latest-<< parameters.platform >>" \ "<< parameters.platform >>" \ - "<< parameters.profile >>" + "$DOCKER_PROFILE" # linking might take a while and doesn't produce CLI output no_output_timeout: 60m @@ -513,7 +525,7 @@ workflows: matrix: parameters: profile: - - quick-release + - release target: - aarch64-apple-darwin - aarch64-unknown-linux-gnu @@ -622,28 +634,17 @@ workflows: - fmt - cargo-audit - build-docker: - <<: *nofork_filter + <<: *docker_filter name: build-docker-amd64 - matrix: - parameters: - platform: [amd64] - resource_class: [2xlarge+] - profile: [quick-release] + platform: amd64 + resource_class: 2xlarge+ - build-docker: - <<: *nofork_filter + <<: *docker_filter name: build-docker-arm64 - matrix: - parameters: - platform: [arm64] - resource_class: [arm.2xlarge] - profile: [quick-release] + platform: arm64 + resource_class: arm.2xlarge - publish-docker: - <<: *main_filter - requires: - - build-docker-amd64 - - build-docker-arm64 - - wait-for-docker: + <<: *docker_filter requires: - build-docker-amd64 - build-docker-arm64 - - publish-docker diff --git a/Dockerfile b/Dockerfile index 3ddb526ad49..b250827630f 100644 --- a/Dockerfile +++ b/Dockerfile @@ -39,7 +39,7 @@ RUN \ FROM debian:bookworm-slim RUN apt update \ - && apt install --yes ca-certificates gettext-base libssl3 python3 python3-dev python3-pip --no-install-recommends \ + && apt install --yes ca-certificates gettext-base libssl3 python3 python3-dev python3-pip wget curl --no-install-recommends \ && rm -rf /var/lib/{apt,dpkg,cache,log} \ && groupadd --gid 1500 influxdb3 \ && useradd --uid 1500 --gid influxdb3 --shell /bin/bash --create-home influxdb3