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)
feeds Atom/RSS feeds for Gentoo Build Publisher 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-3.4.0.tar.gz (151.3 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-3.4.0-py3-none-any.whl (142.7 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: gentoo_build_publisher-3.4.0.tar.gz
  • Upload date:
  • Size: 151.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.12

File hashes

Hashes for gentoo_build_publisher-3.4.0.tar.gz
Algorithm Hash digest
SHA256 a7f22748e8aa317739c4a8321cf95c056d84ad87283005a6b560f6ba0048a294
MD5 0b00e75ba459c8905a6440acaed6998b
BLAKE2b-256 aa2a70a1900fce9172930b8c9fc906c3eb39a208549904916b98f625a96f8518

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for gentoo_build_publisher-3.4.0-py3-none-any.whl
Algorithm Hash digest
SHA256 251fa93c3d29a67e156194438412276acea71f8ba4a49a22ebdfb02c8d148772
MD5 762a27257eb91e4432908dc82aa9546c
BLAKE2b-256 a57cb8235768d891272b266defe3bf3208968731929b9edee1c02fd0e86b0bd8

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