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):/workspace -v $(pwd)/build:/build ghcr.io/observiq/otel-distro-builder:main \
--manifest /workspace/manifest.yaml \
# Optional
--artifacts /workspace/artifacts \
--goos linux \
--goarch amd64 \
--ocb-version 0.121.0 \
--go-version 1.22.1 \
--supervisor-version 0.122.0
- 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_bucket
Options:
-m
: Path to manifest file (required)-p
: Google Cloud project ID-b
: Artifact bucket name
This script is used to build a custom OpenTelemetry Collector distribution using a local Docker container:
./scripts/run_local_build.sh -m manifest.yaml [-o output_dir] [-v ocb_version] [-g go_version]
# Optionally, run it with
make build-local # to get the latest version of the otelcol and ocb
# Or
make build output_dir=./artifacts ocb_version=0.121.0 go_version=1.22.1 supervisor_version=0.122.0
Options:
-m
: Path to manifest file (required)-o
: Directory to store build artifacts (default: ./artifacts)-v
: OpenTelemetry Collector Builder version (default: auto-detected from manifest)-g
: Go version to use for building (default: 1.24.1)
The artifacts will be saved 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:
./artifacts
directory - Cloud builds:
gs://<bucket>/<build_id>/
We follow semantic versioning. The builder is available in several forms:
- GitHub Action: Use
@v1
for latest 1.x version, or@v1.0.5
for specific versions - Docker Image: Use
main
for latest, or version tags likev1.0.5
- Container Registry:
ghcr.io/observiq/otel-distro-builder:main
orghcr.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.