Saturday, May 17, 2025

Speed up CI/CD pipelines with the brand new AWS CodeBuild Docker Server functionality

Voiced by Polly

Beginning immediately, you should utilize AWS CodeBuild Docker Server functionality to provision a devoted and chronic Docker server straight inside your CodeBuild mission. With Docker Server functionality, you may speed up your Docker picture builds by centralizing picture constructing to a distant host, which reduces wait instances and will increase general effectivity.

From my benchmark, with this Docker Server functionality, I diminished the whole constructing time by 98 %, from 24 minutes and 54 seconds to 16 seconds. Right here’s a fast have a look at this characteristic from my AWS CodeBuild tasks.

AWS CodeBuild is a completely managed steady integration service that compiles supply code, runs exams, and produces software program packages prepared for deployment. Constructing Docker photographs is without doubt one of the commonest use circumstances for CodeBuild clients, and the service has progressively improved this expertise over time by releasing options similar to Docker layer caching and reserved capability options to enhance Docker construct efficiency.

With the brand new Docker Server functionality, you may scale back construct time to your purposes by offering a persistent Docker server with constant caching. When enabled in a CodeBuild mission, a devoted Docker server is provisioned with persistent storage that maintains your Docker layer cache. This server can deal with a number of concurrent Docker construct operations, with all builds benefiting from the identical centralized cache.

Utilizing AWS CodeBuild Docker Server
Let me stroll you thru an illustration that showcases the advantages with the brand new Docker Server functionality.

For this demonstration, I’m constructing a posh, multi-layered Docker picture based mostly on the official AWS CodeBuild curated Docker photographs repository, particularly the Dockerfile for constructing a normal Ubuntu picture. This picture comprises quite a few dependencies and instruments required for contemporary steady integration and steady supply (CI/CD) pipelines, making it a superb instance of the kind of massive Docker builds that improvement groups repeatedly carry out.

 # Copyright 2020-2024 Amazon.com, Inc. or its associates. All Rights Reserved. # # Licensed underneath the Amazon Software program License (the "License"). Chances are you'll not use this file besides in compliance with the License. # A replica of the License is situated at # #    http://aws.amazon.com/asl/ # # or within the "license" file accompanying this file. # This file is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, specific or implied. # See the License for the precise language governing permissions and limitations underneath the License. FROM public.ecr.aws/ubuntu/ubuntu:20.04 AS core ARG DEBIAN_FRONTEND="noninteractive" # Set up git, SSH, Git, Firefox, GeckoDriver, Chrome, ChromeDriver,  stunnel, AWS Instruments, configure SSM, AWS CLI v2, env instruments for runtimes: Dotnet, NodeJS, Ruby, Python, PHP, Java, Go, .NET, Powershell Core,  Docker, Composer, and different utilities COMMAND REDACTED FOR BREVITY # Activate runtime variations particular to picture model. RUN n $NODE_14_VERSION RUN pyenv  international $PYTHON_39_VERSION RUN phpenv international $PHP_80_VERSION RUN rbenv  international $RUBY_27_VERSION RUN goenv international  $GOLANG_15_VERSION # Configure SSH COPY ssh_config /root/.ssh/config COPY runtimes.yml /codebuild/picture/config/runtimes.yml COPY dockerd-entrypoint.sh /usr/native/bin/dockerd-entrypoint.sh COPY authorized/bill_of_material.txt /usr/share/doc/bill_of_material.txt COPY amazon-ssm-agent.json /and many others/amazon/ssm/amazon-ssm-agent.json ENTRYPOINT ["/usr/local/bin/dockerd-entrypoint.sh"] 

This Dockerfile creates a complete construct surroundings with a number of programming languages, construct instruments, and dependencies – precisely the kind of picture that will profit from persistent caching.

Within the construct specification (buildspec), I take advantage of the docker buildx construct . command:

model: 0.2 phases:   construct:     instructions:       - cd ubuntu/normal/5.0       - docker buildx construct -t codebuild-ubuntu:newest . 

To allow the Docker Server functionality, I navigate to the AWS CodeBuild console and choose Create mission. I can even allow this functionality when enhancing present CodeBuild tasks.

I fill in all particulars and configuration. Within the Setting part, I choose Further configuration.

Then, I scroll down and discover Docker server configuration and choose Allow docker server for this mission. Once I choose this selection, I can select a compute kind configuration for the Docker server. Once I’m completed with the configurations, I create this mission.

Now, let’s see the Docker Server functionality in motion.

The preliminary construct takes roughly 24 minutes and 54 seconds to finish as a result of it must obtain and compile all dependencies from scratch. That is anticipated for the primary construct of such a posh picture.

For subsequent builds with no code adjustments, the construct takes solely 16 seconds and that reveals 98% discount in construct time.

Trying on the logs, I can see that with Docker Server, most layers are pulled from the persistent cache:

The persistent caching offered by the Docker Server maintains all layers between builds, which is especially useful for giant, advanced Docker photographs with many layers. This demonstrates how Docker Server can dramatically enhance throughput for groups working quite a few Docker builds of their CI/CD pipelines.

Further issues to know
Listed here are a few issues to notice:

  • Structure help – The characteristic is accessible for each x86 (Linux) and ARM builds.
  • Pricing – To be taught extra about pricing for Docker Server functionality, consult with the AWS CodeBuild pricing web page.
  • Availability – This characteristic is accessible in all AWS Areas the place AWS CodeBuild is obtainable. For extra details about the AWS Areas the place CodeBuild is accessible, see the AWS Areas web page.

You possibly can be taught extra in regards to the Docker Server characteristic within the AWS CodeBuild documentation.

Comfortable constructing! —

Donnie Prakoso


How is the Information Weblog doing? Take this 1 minute survey!

(This survey is hosted by an exterior firm. AWS handles your info as described within the AWS Privateness Discover. AWS will personal the information gathered by way of this survey and won’t share the knowledge collected with survey respondents.)

Related Articles

LEAVE A REPLY

Please enter your comment!
Please enter your name here

Latest Articles