Build custom OpenTelemetry Collector Distributions from manifest files with a local build utility, Docker, Google Cloud Build, or a GitHub Action.
Quick Start β’ Documentation β’ Examples
Built on top of the OpenTelemetry Collector Builder (OCB), it uses a manifest.yaml to define the components you need, then automates packaging for multiple platforms and manages version releases via GitHub.
While OCB (OpenTelemetry Collector Builder) focuses on building single collector binaries, the OpenTelemetry Distribution Builder provides a complete distribution management solution:
- π¨ Builds multi-platform binaries using OCB under the hood
- π¦ Generates installation packages following OTel community best practices
- π Automates versioned releases through GitHub Actions
- π Simplifies updates through manifest-based configuration
It handles all the complex aspects of managing your own distribution that have historically made building custom collectors challenging. With the OpenTelemetry Distribution Builder, you can focus on defining your components while the tooling takes care of the rest.
- π― Custom Component Selection: Build distributions with exactly the components you need
- π Multi-Platform Support: Build for multiple architectures (amd64, arm64)
- π¦ Multiple Package Formats: Generate APK, DEB, RPM, and TAR.GZ packages
- π GitHub Actions Integration: Seamless CI/CD integration
- π Automated Releases: Streamlined versioning and release process
- π Platform-Specific Builds: Optimize for your target environment
-
Create a new repository
-
Add your manifest file (
manifest.yaml):dist: name: my-otelcol description: My Custom OpenTelemetry Collector Distro # ... extensions: - # ... exporters: - # ... processors: - # ... receivers: - # ... connectors: - # ... providers: - # ...
-
Set up GitHub Actions (
.github/workflows/build.yml):
name: OpenTelemetry Distribution Build
on:
push:
tags:
- "v*"
workflow_dispatch:
permissions:
contents: write # This is required for creating/modifying releases
jobs:
build:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
# Build the OpenTelemetry distribution using this custom action
- uses: observiq/otel-distro-builder@v1
with:
manifest: "./manifest.yaml"
# Create a GitHub Release and attach the build artifacts
# This makes the artifacts available for download from the Releases page
- name: Create Release
uses: softprops/action-gh-release@v2
with:
files: ${{ github.workspace }}/artifacts/*-
Trigger a build:
git tag v1.0.0 && git push --tags -
(Optional) Build with Docker:
docker pull ghcr.io/observiq/otel-distro-builder:main docker run --rm -v $(pwd):/workspace -v $(pwd)/build:/build ghcr.io/observiq/otel-distro-builder:main \ --manifest /workspace/manifest.yaml
To view detailed guides, see the docs directory.
| Input | Description | Default |
|---|---|---|
manifest |
Path to manifest file | ./manifest.yaml |
platforms |
Target platforms | linux/amd64 |
All generated packages and binaries are available in the ${{ github.workspace }}/artifacts/* folder.
# Pull the latest version
docker pull ghcr.io/observiq/otel-distro-builder:latest
# Pull specific version
docker pull ghcr.io/observiq/otel-distro-builder:v1.0.5
# Run a build
docker run --rm \
-v "$(pwd)/manifest.yaml:/manifest.yaml:ro" \
-v "$(pwd)/artifacts:/artifacts" \
ghcr.io/observiq/otel-distro-builder:latest \
--manifest /manifest.yaml \
--artifacts /artifacts \
--goos darwin,linux,windows \
--goarch amd64,arm64 \
--ocb-version 0.123.0 \
--supervisor-version 0.123.0 \
--go-version 1.24.1 \
--parallelism 4Optional builder arguments: --platforms, --goos, --goarch, --ocb-version, --supervisor-version, --go-version, --parallelism (number of parallel Goreleaser build tasks; default 4; lower to reduce memory use).
Read more details in the Docker documentation.
When building for multiple architectures or large manifests, the number of parallel Goreleaser build tasks (--parallelism) directly affects memory usage and build time. Here are real-world benchmarks for different parallelism settings (measured on a MacBook Pro M4 Pro with 48GB RAM, Docker Engine set to 14 CPUs + 24GB RAM):
| Build Targets | Parallelism | Duration |
|---|---|---|
Single architecture (darwin/arm64) |
1 | 05m 56s |
Single architecture (darwin/arm64) |
4 | 04m 44s |
Single architecture (darwin/arm64) |
14 | 05m 26s |
Single architecture (linux/arm64) |
1 | 05m 23s |
Single architecture (linux/arm64) |
4 | 05m 45s |
Single architecture (linux/arm64) |
14 | 04m 38s |
Single architecture (linux/amd64) |
14 | 05m 06s |
Multi-architecture (darwin/arm64,darwin/amd64) |
1 | 07m 12s |
Multi-architecture (darwin/arm64,darwin/amd64) |
4 | 08m 04s |
Multi-architecture (darwin/arm64,darwin/amd64) |
14 | 06m 56s |
Multi-architecture (linux/arm64,linux/amd64) |
1 | 10m 09s |
Multi-architecture (darwin/arm64,linux/arm64) |
1 | 08m 27s |
Multi-architecture (darwin/arm64,linux/arm64) |
4 | 07m 19s |
Multi-architecture (darwin/arm64,linux/arm64) |
14 | 07m 32s |
Multi-architecture (darwin/arm64,linux/amd64) |
1 | 14m 02s |
Multi-architecture (darwin/arm64,linux/amd64) |
4 | 12m 14s |
Multi-architecture (darwin/arm64,linux/amd64) |
14 | 11m 13s |
Multi-architecture (darwin/arm64,darwin/amd64,linux/arm64,linux/amd64) |
1 | 14m 06s |
Multi-architecture (darwin/arm64,darwin/amd64,linux/arm64,linux/amd64) |
14 | 11m 21s |
Multi-architecture (darwin/arm64,darwin/amd64,linux/arm64,linux/amd64) |
16 | 10m 55s |
Single architecture (darwin/arm64) |
48 | 03m 43s |
Single architecture (linux/amd64) |
48 | 04m 36s |
- Lower
--parallelismreduces peak memory use and may be required for constrained environments or very large builds, at the expense of longer build times. - Higher
--parallelismcan speed up builds if you have sufficient memory, but may cause OOM failures on systems with limited RAM. In particular for multi-architecture builds for multiple platforms. - For collector builds with many components, ensure Docker/host RAM is at least 4β6 GB (more for larger/parallel builds).
See Docker documentation for more details and troubleshooting tips.
- Python 3
- Docker
- Make
# Show all commands
make help
# Setup development environment
make setup
# Run tests
make test
# Run linting
make lint
Triggers a build using Google Cloud Build:
./scripts/run_cloud_build.sh -m manifest.yaml -p project_id -b artifact_bucketOptions:
-m: Path to manifest file (required)-p: Google Cloud project ID-b: Artifact bucket name
Build a custom OpenTelemetry Collector distribution using a local Docker container (single or custom platform):
# Basic build (host platform)
./scripts/run_local_build.sh -m manifest.yaml
# Custom output directory and versions
./scripts/run_local_build.sh -m manifest.yaml -o ./dist -v 0.121.0 -s 0.122.0 -g 1.24.1
# Build Docker image for a specific platform (e.g. Apple Silicon / arm64)
./scripts/run_local_build.sh -m manifest.yaml -p linux/arm64
# Multiple platforms for Docker image (comma-delimited)
./scripts/run_local_build.sh -m manifest.yaml -p linux/arm64,linux/amd64Options: -m (required), -o (output dir), -p (platforms), -v (OCB version), -g (Go version), -s (Supervisor version). When running the container directly, you can also pass --parallelism N to the builder (default 4; lower for less memory use).
Via Make: make build, make build-local, make build output_dir=./artifacts ocb_version=0.121.0, make build platforms=linux/arm64,linux/amd64.
Build collector binaries for multiple architectures in one run (default: linux/amd64, linux/arm64, darwin/arm64):
# Default: collector for linux/amd64, linux/arm64, darwin/arm64
./scripts/run_local_multiarch_build.sh -m manifest.yaml
# Custom platforms only
./scripts/run_local_multiarch_build.sh -m manifest.yaml -p linux/amd64,linux/arm64
# With output dir and versions
./scripts/run_local_multiarch_build.sh -m manifest.yaml -o ./dist -v 0.121.0 -s 0.122.0 -g 1.24.1Options: -m (required), -o (output dir), -p (GOOS/GOARCH list), -v, -g, -s. When running the container directly, you can also pass --parallelism N to the builder (default 4).
Via Make: make build-multiarch, make build-multiarch-local.
Artifacts are written to the specified output directory (default: ./artifacts).
otel-distro-builder/
βββ builder/ # Builder application
β βββ src/ # Core builder code
β βββ templates/ # Build templates
β βββ tests/ # Test suite
β βββ Dockerfile # Builder image definition
βββ action/ # GitHub Action
βββ scripts/ # Build scripts
βββ Makefile # Development commands
- Builder Image Preparation: Build and push to registry
- Manifest Processing: Upload and validate manifest configuration
- Build Execution:
- Download OpenTelemetry Collector Builder (OCB)
- Generate Go source files
- Build platform-specific packages
- Create SBOMs and checksums
- Artifact Management: Upload to GitHub, Google Cloud Storage, or save locally
The builder produces:
- π¦ Binary packages (APK, DEB, RPM)
- π Source tarball
- π§ Raw binary
- π SBOM files
- π Checksums
- π Build metadata
- Local builds:
./artifactsdirectory - Cloud builds:
gs://<bucket>/<build_id>/
We follow semantic versioning. The builder is available in several forms:
- GitHub Action: Use
@v1for latest 1.x version, or@v1.0.5for specific versions - Docker Image: Use
mainfor latest, or version tags likev1.0.5 - Container Registry:
ghcr.io/observiq/otel-distro-builder:mainorghcr.io/observiq/otel-distro-builder:v1.0.5
Check out our example workflows in .github/workflows/examples/ for common use cases:
- Multi-platform builds
- Container publishing
- Custom package configurations
We welcome contributions! Please see our Contributing Guide for details.
This project is licensed under the Apache 2.0 License - see the LICENSE file for details.