Skip to main content

Gentoo Build Publisher

Project description

Gentoo Build Publisher dashboard

Gentoo Build Publisher

Introduction

Gentoo Build Publisher (GBP) is a Gentoo build server, binary package host (binhost), ebuild repo server, and configuration manager in one which uses continuous integration and other tools to deliver successful, consistent "builds" for a single machine or multiple heterogeneous Gentoo machines.

In case you didn't know, Gentoo Linux is a source-based rolling-release meta-distribution that you can twist and mold into pretty much anything you like. That's just a verbose way of saying Gentoo is awesome.

If you run a Gentoo system, say a laptop, you may be updating your system using the standard emerge --sync followed by a world update. This pulls in the latest ebuilds from the Gentoo repo and if there are any updates applicable to your system then they get built on your system.

Except sometimes they don't.

Sometimes builds fail. Sometimes USE flags need to be changed. Sometimes there's an update to a piece of software that is buggy and you want to revert. Sometimes a build takes a long time and you don't want to wait.

Well since Gentoo is the distribution you build yourself, CI/CD seems like a natural fit. Enter Gentoo Build Publisher.

Gentoo Build Publisher combines a repo/overlay server, basic configuration management, and binary package server (binhost) for complete and atomic builds. Successful builds performed by Jenkins are served by GBP where client machines sync from.

Procedure

  • Build a Gentoo Build Publisher instance. Refer to the Install Guide.
  • Create "machines" and "repos" jobs in Jenkins. For example gbp addrepo gentoo https://anongit.gentoo.org/git/repo/gentoo.git; gbp addmachine base https://github.com/enku/gbp-machines.git Use the gbp-machines repo as a starting point. This can also be done manually within the Jenkins UI.
  • Once a Jenkins job has been pulled by Gentoo Build Publisher it can be published so that actual machines can use it (e.g. rsync for repos, http for binpkgs). Use the CLI (gbp publish) to publish a pulled build.
  • If the job fails, it will not be pulled.
  • Your real machine, for example, base, syncs from, rsync://gbp/repos/base/gentoo. You can dynamically acquire the repos.conf file from https://gbp/machines/base/repos.conf and the binrepos.conf from https://gbp/machines/base/binrepos.conf.

Jenkins build

CLI

The command-line interface can inspect, publish, pull, schedule builds and more.

gbpcli screenshot

Plugins

Various plugins exist for Gentoo Build Publisher. Some are "server" plugins, meaning they plug into Gentoo Build Publisher, the server. Others are "client" plugins, meaning they plug into the CLI. And some are both. The following Plugins are available.

Plugin Description Client/Server
archive A plugin to dump and restore builds Both (but only runs on from the server)
fl A pfl-inspired plugin Both
notifications A plugin that can send notifications when events occur Server
ps A plugin to display your Gentoo Build Publisher processes Both
purge A plugin to purge old builds Server
webhook A webhook for gbp-notifications to display desktop notifications and more Client

Articles

Below are some articles that explain some aspects of Build Publisher in detail.

Project details


Download files

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

Source Distribution

gentoo_build_publisher-2.6.0.tar.gz (128.0 kB view details)

Uploaded Source

Built Distribution

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

gentoo_build_publisher-2.6.0-py3-none-any.whl (123.4 kB view details)

Uploaded Python 3

File details

Details for the file gentoo_build_publisher-2.6.0.tar.gz.

File metadata

  • Download URL: gentoo_build_publisher-2.6.0.tar.gz
  • Upload date:
  • Size: 128.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.5

File hashes

Hashes for gentoo_build_publisher-2.6.0.tar.gz
Algorithm Hash digest
SHA256 681c7c1d5ff1879450cd4cafb259fe27ab5e2248d64e52f90d3c282f117efe12
MD5 82db1ac3ee880590a8492fdb58953ffc
BLAKE2b-256 a6455071d624ade569502648415adfaaf908dcad0ec32b372d13853a88aa0c6a

See more details on using hashes here.

File details

Details for the file gentoo_build_publisher-2.6.0-py3-none-any.whl.

File metadata

File hashes

Hashes for gentoo_build_publisher-2.6.0-py3-none-any.whl
Algorithm Hash digest
SHA256 015572a2577e1f1e7c6d600c206527a0c963e2ee7c6b90049ac86e3ebb7a152b
MD5 464b111d2fc2f9a7f93e7cde5ac6237d
BLAKE2b-256 37d1345ceadf08a15145c418310e85f36ac5203874790319c7faf1651e366605

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