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.0.0.tar.gz (135.2 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.0.0-py3-none-any.whl (131.5 kB view details)

Uploaded Python 3

File details

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

File metadata

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

File hashes

Hashes for gentoo_build_publisher-3.0.0.tar.gz
Algorithm Hash digest
SHA256 718a9130638674307959756c108694b08aca2a730215cf57078479fb06706ce9
MD5 1f0715ca4cec11b902e3666a27ca007c
BLAKE2b-256 cfae72f111e76a064fba8b1fcda2e14ceaf2e7fa87cf56e0f008a37e435f3974

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for gentoo_build_publisher-3.0.0-py3-none-any.whl
Algorithm Hash digest
SHA256 271aaff962883cebc83a1fb99402f54df12397b0167dc2695f3e99cb0cb1b372
MD5 0e7fc718c1b46025eed0daa96207287e
BLAKE2b-256 39f4142725ce757272a01180d03ab4a5f9da099f064613809393798e0951b63f

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