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. Among them are:

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.4.0rc1.tar.gz (110.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-2.4.0rc1-py3-none-any.whl (100.5 kB view details)

Uploaded Python 3

File details

Details for the file gentoo_build_publisher-2.4.0rc1.tar.gz.

File metadata

File hashes

Hashes for gentoo_build_publisher-2.4.0rc1.tar.gz
Algorithm Hash digest
SHA256 4c180987127cafcfa75c2ca9c3140dabb2badcad0e4528f1d4f9366fc4e636af
MD5 ac24c765428148698db275f6f7a5d94d
BLAKE2b-256 390c3a534a7c2dd0efc22ae230f550691553b4faaa4d010646a61a3719066304

See more details on using hashes here.

File details

Details for the file gentoo_build_publisher-2.4.0rc1-py3-none-any.whl.

File metadata

File hashes

Hashes for gentoo_build_publisher-2.4.0rc1-py3-none-any.whl
Algorithm Hash digest
SHA256 93cad2e9f7cfe7872c4a4d3d0523642f34a233d9259252ab4e91e0b2c3e3c878
MD5 b802aca4bf3136b76c7b7d87f5e9275f
BLAKE2b-256 f5ae4ff489f02299770466288bd4c4b059217ef5d948dd5f42f98330df19014b

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