Quickstart
This guide shows you how to build packages and containers from source using Dalec.
What is Dalec?
Dalec is a Docker Buildkit frontend that translates a YAML spec into build instructions for creating packages (RPMs, DEBs) and container images. It requires only Docker to run.
note
All Dalec spec files must start with # syntax=ghcr.io/azure/dalec/frontend:latest to tell buildkit which frontend to use.
How it Works
Dalec builds happen in stages:
- Package Build - Check out sources and build packages using your defined build steps
- Package Test - Install and test the package in a clean environment
- Create Container (optional) - Install the package(s) into a scratch image to create a container
Example: Building go-md2man
Let's build the go-md2man package from source. We need:
- Sources to pull from
- Build instructions
- Artifacts to include in the package
Here's the complete Dalec spec file:
# syntax=ghcr.io/azure/dalec/frontend:latest
name: go-md2man
version: 2.0.3
revision: "1"
packager: Dalec Example
vendor: Dalec Example
license: MIT
description: A tool to convert markdown into man pages (roff).
website: https://github.com/cpuguy83/go-md2man
sources:
  src:
    generate:
      - gomod: {}  # Pre-downloads Go modules since network is disabled during build
    git:
      url: https://github.com/cpuguy83/go-md2man.git
      commit: "v2.0.3"
dependencies:
  build:
    golang:
build:
  env:
    CGO_ENABLED: "0"
  steps:
    - command: |
        cd src
        go build -o go-md2man .
artifacts:
  binaries:
    src/go-md2man:
image:
  entrypoint: go-md2man
  cmd: --help
tests:
  - name: Check bin
    files:
      /usr/bin/go-md2man:
        permissions: 0755
Key sections explained:
- Metadata: Package name, version, license, and description (see spec)
- Sources: Git qrepository to clone, with generateto pre-download Go modules (see sources)
- Dependencies: Build-time dependencies (golang) (see spec)
- Build: Environment variables and build commands (see spec)
- Artifacts: Files to include in the package (see artifacts)
- Image: Container entrypoint and default command (see spec)
- Tests: Validation that the package was built correctly (see testing)
Building the Package
Build an RPM package
docker build -t go-md2man:2.0.3 -f docs/examples/go-md2man.yml --target=azlinux3/rpm --output=_output .
This creates RPM and SRPM directories in _output/ with the built packages.
Build a container image
docker build -t go-md2man:2.0.3 -f docs/examples/go-md2man.yml --target=azlinux3 .
This produces a container image named go-md2man:2.0.3.
note
See the targets section for all available build targets.