Skip to main content

Swarm it. Build it. Run it. — Managing container base and library images has never been easier.

Project description

ContainerHive

LICENSE CircleCI codecov GitHub Release Renovate pre-commit


Swarm it. Build it. Run it. — Managing container base and library images has never been easier.

Motivation

Managing container base images and library images at scale is surprisingly painful. Teams end up with scattered Dockerfiles, manual build scripts, inconsistent tagging, and no dependency tracking between images. CI pipelines are hand-rolled per project, caching is an afterthought, and reproducibility is a dream.

ContainerHive grew out of poc-container-image-manager, a Python-based proof of concept that validated the core idea: declarative, YAML-driven image management with dependency resolution, templating, and CI generation. The PoC proved the concept works — but being Python-based, it required a runtime, bundled platform-specific binaries, and wasn't practical to distribute as a single portable tool.

ContainerHive is the production-grade successor, rewritten in Go as a single static binary with no external dependencies beyond BuildKit. It takes the validated ideas from the PoC and packages them into something you can drop into any CI pipeline or developer workstation without setup overhead.

Features

  • Next-gen builds: Powered by BuildKit, the modern container image builder behind Docker.
  • Multi-platform ready: Build and push images for any architecture in a single workflow.
  • YAML-driven management: Define and maintain image sets and variants declaratively.
  • Reproducible layers: Guarantee consistent, bit-for-bit identical builds every time (given the same inputs).
  • Testing built in: Validate images as part of the build process, no extra tooling needed.
  • Smart caching: Optimized caching via S3 or registry backends, no manual tuning required.
  • SBOM generation: Generate CycloneDX SBOMs for all built images using Syft.
  • CI pipeline generation: Generate GitLab CI and GitHub Actions pipelines from your project definition.
  • Bring your own BuildKit: Connect to any BuildKit instance — local daemon, shared cluster service, or sidecar in a hardened Kubernetes environment.
  • Enterprise-ready: Built for scale, compliance, and integration with enterprise workflows.

Supported platforms

The following platforms have prebuilt binaries:

  • Linux
    • 64-bit
    • ARM 64-bit
  • Darwin
    • 64-bit (Intel)
    • ARM 64-bit (Apple Silicon)
  • Docker (x86 & ARM)

Requirements

  • BuildKit daemon
  • S3-compatible storage for caching (optional)

Installation

See the installation guide for detailed instructions.

Documentation

Documentation is available at container-hive.timo-reymann.de, hosted on GitHub Pages.

Contributing

I love your input! I want to make contributing to this project as easy and transparent as possible, whether it's:

  • Reporting a bug
  • Discussing the current state of the configuration
  • Submitting a fix
  • Proposing new features
  • Becoming a maintainer

To get started please read the Contribution Guidelines.

Development

Requirements

Test

make test-coverage-report

Build

make build

AI Usage

This project uses AI tooling to assist with development. All AI-generated or AI-assisted changes are human-reviewed and applied responsibly — this is not AI slop. Contributors are expected to uphold the same standard: AI tools are welcome, but every change must be understood, reviewed, and owned by the person submitting it.

Credits

Without these libraries this project would not be possible:

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distributions

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distributions

If you're not sure about the file name format, learn more about wheel file names.

containerhive-0.17.1-py3-none-manylinux_2_17_aarch64.manylinux2014_aarch64.whl (68.7 MB view details)

Uploaded Python 3manylinux: glibc 2.17+ ARM64

containerhive-0.17.1-py3-none-manylinux_2_12_x86_64.manylinux2010_x86_64.whl (74.2 MB view details)

Uploaded Python 3manylinux: glibc 2.12+ x86-64

containerhive-0.17.1-py3-none-macosx_11_0_arm64.whl (73.8 MB view details)

Uploaded Python 3macOS 11.0+ ARM64

containerhive-0.17.1-py3-none-macosx_10_9_x86_64.whl (77.7 MB view details)

Uploaded Python 3macOS 10.9+ x86-64

File details

Details for the file containerhive-0.17.1-py3-none-manylinux_2_17_aarch64.manylinux2014_aarch64.whl.

File metadata

File hashes

Hashes for containerhive-0.17.1-py3-none-manylinux_2_17_aarch64.manylinux2014_aarch64.whl
Algorithm Hash digest
SHA256 0a95ac7d5fc9662a2ec766d4d36ed382590cb4489f4d75fe4c0310316490fee7
MD5 53107d64f01dde6b7b711d4d02f5d75c
BLAKE2b-256 7a32c2cb5d5cfd9690d0af4a75045b08b74d9e7de0179225fd20034478875fce

See more details on using hashes here.

File details

Details for the file containerhive-0.17.1-py3-none-manylinux_2_12_x86_64.manylinux2010_x86_64.whl.

File metadata

File hashes

Hashes for containerhive-0.17.1-py3-none-manylinux_2_12_x86_64.manylinux2010_x86_64.whl
Algorithm Hash digest
SHA256 f48bfa38b0aeae88cb84add017da9477b567520a2e14a3540d1d5079b3a48549
MD5 c8ac7008acce970f8174da95f98ee7ed
BLAKE2b-256 3d12701c6dcaabc66d70a917067502ef3b41c39f6367634acdbb1af439b32f65

See more details on using hashes here.

File details

Details for the file containerhive-0.17.1-py3-none-macosx_11_0_arm64.whl.

File metadata

File hashes

Hashes for containerhive-0.17.1-py3-none-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 0a62d37c9bf3683a0515adeaeaedbdc653d57c1b068aeb798a41a27010443f7d
MD5 a446681a6c0d639fac0de1dcb3c50555
BLAKE2b-256 0221c7d31437a18713a4b463be51eecbc92ccb34d5c9dc51ea36b4a3e59dd3ab

See more details on using hashes here.

File details

Details for the file containerhive-0.17.1-py3-none-macosx_10_9_x86_64.whl.

File metadata

File hashes

Hashes for containerhive-0.17.1-py3-none-macosx_10_9_x86_64.whl
Algorithm Hash digest
SHA256 d3483fafaed07bdcc57a87aed30bc4d6c418a522c9dc1611175c601a2512c3cc
MD5 1454e56ae67fbeeb22c6427d30a6df02
BLAKE2b-256 1e07809b99f3c986cfb7b21ecc52e7a44cf51d7d53c6485040f402fc87bbe5e7

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page