Skip to content

Latest commit

 

History

History
80 lines (58 loc) · 3.1 KB

README.md

File metadata and controls

80 lines (58 loc) · 3.1 KB

OE Build Container

A Linux container for production OE/Yocto/Yoe builds.

Why?

OE builds require a small number of dependencies that must be installed. This is not a huge deal, but can take 30-60 minutes to figure out what they all are and wait for them to install. This container gives you everything you need.

Additionally, production builds require a known build environment where package versions are not changing. Using a container for OE builds allows team members to use whatever Linux distro they want on their workstations, but all have access to a common build environment for OE builds.

Example

See the following for information on how to use this container with OE builds:

Some notes on the above:

  • The Yoe distro template is a simple wrapper around OE designed for product development needs. See http://yoedistro.org for more information. You can use your own OE/Yocto build tree -- this is just for example purposes.
  • The build directory is mapped into the container at the same location as the host. This keeps things simple and ensures that any paths in generated config files are the same in the container, and on the host.
  • Host ssh keys are mapped into container so that we can clone project git repos using ssh authentication.
  • Host gitconfig is mapped into the container as well in case the build requires any git push operations (such as tagging).

This example illustrates several fundamental principals of Docker:

  1. use Docker for apps/standard stuff, but keep data and build dirs in your host file system
  2. don't work in the context of the container, only use it to run commands (bitbake in this case)
  3. don't store state in the container -- keep that in your host file system

Details

This container is based on Debian. Debian has proven to be an excellent OS for production OE builds where you might need to generate builds for a project over a period of years. OE can be rather fussy about versions of host packages (such as gcc, make, etc) so having a build distro where these are locked down is essential.

Processes in the container run as the "build" user by default, so it may be necessary that the user in your host has UID 1000 so they match. If necessary, create a special use with UID 1000 to do OE builds on your build machine.

Building and pushing an updated image to docker hub

  • clone this repo
  • make sure docker-buildx is installed
  • build: DOCKER_BUILDKIT=1 docker build -t yoedistro/yoe-build:bullseye-x86_64 . (note period at end)
  • test: docker run -it yoedistro/yoe-build:bullseye-x86_64 /bin/bash
  • copy to legacy name: docker tag yoedistro/yoe-build:bullseye-x86_64 yoedistro/yoe-build:bullseye
  • push: docker image push yoedistro/yoe-build:bullseye-x86_64
  • push: docker image push yoedistro/yoe-build:bullseye

The push step likely requires some type of auth setup, but the errors will likely guide you through it.

License

MIT

Author

Cliff Brake [email protected]

improvements/pull requests welcome!