Tools for managing GitLab CI build artifacts
Project description
Glartifacts
Python utility to analyze and clean up GitLab artifacts.
Glartifacts is a tool designed to help GitLab administrators manage CI job artifacts. The artifact expiration functionality provided by GitLab (11.6, as of this writing) is primitive. The goal of this project is to design and implement improved artifact expiration policies which act as a model for future GitLab improvements.
See the documentation for more detail on how glartifacts works and how to use it.
Requirements
Glartifacts requires Python 3.
It is also a tool for GitLab administrators, designed to run as root on the GitLab server. It connects directly to the GitLab database and Gitaly gRPC service.
Warning: Backup your database and artifacts
Be sure you have a GitLab backup before you start.
Glartifacts modifies the ci_builds.artifacts_expire_at
column in the GitLab
database. The next execution of the Sidekiq
background task will remove
CI artifacts from the database and file system. Once removed, artifacts
are non-recoverable.
Installation
Glartifacts from PyPI using pip.
$ sudo pip install glartifacts
Configuration
Glartifacts requires access to the GitLab database and Gitaly server. The
default connection settings are based on a standard Omnibus install, but can be
modified for custom deployments via settings in glartifacts.conf
. You can
also override individual settings per-invocation using environment variables.
The table below lists the available configuration options:
Section | Option | ENV var | Default |
---|---|---|---|
postgres | dbname | GLARTIFACTS_DBNAME |
gitlabhq_production |
postgres | user | GLARTIFACTS_DBUSER |
gitlab |
postgres | host | GLARTIFACTS_DBHOST |
/var/opt/gitlab/postgresql |
postgres | port | GLARTIFACTS_DBPORT |
5432 |
gitaly | address | GLARTIFACTS_GITALYADDR |
unix:/var/opt/gitlab/gitaly/gitaly.socket |
The following paths are searched for the glartifacts.conf. Settings are merged
for each conf file found: Defaults
> System Settings
> User Settings
.
$HOME/.config/glartifacts/glartifacts.conf
/etc/glartifacts/glartifacts.conf
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Hashes for glartifacts-2.1.1-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | e40f4806c7977c0af9fa503f73fb4ebf0940cb82f17aa4f5428c164bfa5c6cad |
|
MD5 | 25f221ac763fb4be894c6263f797c86a |
|
BLAKE2b-256 | 2752f0ac5920331a48aa23bdf63223941ec967247e973a20a0d9123edfb02995 |