Skip to main content

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


Download files

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

Source Distribution

glartifacts-2.4.0.tar.gz (120.1 kB view details)

Uploaded Source

Built Distribution

glartifacts-2.4.0-py3-none-any.whl (144.6 kB view details)

Uploaded Python 3

File details

Details for the file glartifacts-2.4.0.tar.gz.

File metadata

  • Download URL: glartifacts-2.4.0.tar.gz
  • Upload date:
  • Size: 120.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.2

File hashes

Hashes for glartifacts-2.4.0.tar.gz
Algorithm Hash digest
SHA256 0664bdb3abeb1bfa7f496789ada49aab209bc0cb3828e21bea9f3d0129199384
MD5 1cfc7869305f16c06abd18e5c07ade5e
BLAKE2b-256 f6b5be8c286e18a2b4e8ead4f21f2529343b822d91d1b9db9551dcf33afd2a17

See more details on using hashes here.

File details

Details for the file glartifacts-2.4.0-py3-none-any.whl.

File metadata

  • Download URL: glartifacts-2.4.0-py3-none-any.whl
  • Upload date:
  • Size: 144.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.2

File hashes

Hashes for glartifacts-2.4.0-py3-none-any.whl
Algorithm Hash digest
SHA256 c02ed189325d40efbf0feed37c32f99bacdfa3c49e61fbf80b3292bd67345e54
MD5 c7d7d474c4725ea14f1a660cadea7bae
BLAKE2b-256 a6508934d5a7834dc31dfdb18140fa8304bf313be4ec2b45c85f6b87b9c6034f

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page