Skip to content

🐳Run your buildkite builds inside an ephemeral per-job container

Notifications You must be signed in to change notification settings

buildkite/docker-bootstrap-example

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

5 Commits
 
 
 
 

Repository files navigation

Example: Docker Bootstrap

This is an example of using a custom buildkite bootstrap script to run an entire Buildkite build inside an ephemeral docker container.

Installing

Download bootstrap.sh and put it someone on your agent host. Set bootstrap-script-path to reference the bootstrap script. If running, you will need to restart your agent so it picks up the new config.

Alternately, you can run an agent in a docker container that uses this bootstrap to run jobs in containers. Meta.

docker run --rm \
  -v "$PWD/bootstrap.sh:/bootstrap.sh:ro" \
  -v "/var/run/docker.sock:/var/run/docker.sock" \
  -e "BUILDKITE_AGENT_TOKEN" \
  -e "BUILDKITE_BOOTSTRAP_SCRIPT_PATH=/bootstrap.sh" \
  buildkite/agent:3.0.1

How it works

The Buildkite Agent invokes a "bootstrap" subprocess to handle each job. This is typically buildkite-agent bootstrap, which runs the entire process for a job from checkout, to plugins, to hooks. The output from the bootstrap script is what is sent to the UI on buildkite.com.

This provides a script that wraps the agent bootstrap process in an ephemeral docker container. This provides a level of protection against hostile scripts messing with the host that your buildkite-agent is run on.

Security

At this stage, this is just a first line defense. There are still many aspects that we need to get right before it's safe to run third party builds.

Access to Docker Socket

At present, the docker socket from the host isn't mounted into the container, as it can be used to access the host filesystem basically as root (or whatever the docker daemon is running at).

The plan is to private a proxied socket with https://github.com/buildkite/sockguard that locks down what the socket can be used for.

Access to Local Network

Things running in the container can still access local network things which can lead to SSRF attacks that disclose things like Amazon's cloud meta-data endpoints or other secrets available over http.

The plan is to solve this with firewall rules and something like https://github.com/lyft/metadataproxy.

Credit

Thanks to @haines for his work on https://github.com/haines/buildkite-docker-bootstrap which this is derived from 🙇🏼‍♂️

About

🐳Run your buildkite builds inside an ephemeral per-job container

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages