Skip to main content

This project provides an textfile-based exporter for apt-repositories

Project description

Prometheus PKG Exporter

This project provides an textfile-based exporter for apt-repositories.

The Project is in its early development phases. Interfaces may change without notice. Compatibility and Stability do vary.

For the changelog, use the Releases-Section on GitHub

Exported Metrics

At the moment, the packages installed, upgradable, broken and autoremovable are exported per repository as gauge. The label set depends on the packet manager type.

Additionally, pkg_reboot_required is exported to indicate that an reboot is needed.

# HELP pkg_reboot_required Node Requires an Reboot
# TYPE pkg_reboot_required gauge
pkg_reboot_required 1.0
# HELP pkg_update_start_time timestamp of last apt update start
# TYPE pkg_update_start_time gauge
pkg_update_start_time 1.641382890503045e+09
# HELP pkg_update_end_time Timestamp of last apt update finish
# TYPE pkg_update_end_time gauge
pkg_update_end_time 1.641382892755024e+09
# HELP pkg_update_time_available Availability of the apt update timestamp
# TYPE pkg_update_time_available gauge
pkg_update_time_available 1.0
# HELP pkg_installed Installed packages per origin
# TYPE pkg_installed gauge
pkg_installed{archive="focal-updates",component="main",label="Ubuntu",origin="Ubuntu",site="ftp.fau.de",trusted="True"} 672.0
# HELP pkg_upgradable Upgradable packages per origin
# TYPE pkg_upgradable gauge
pkg_upgradable{archive="focal-updates",component="main",label="Ubuntu",origin="Ubuntu",site="ftp.fau.de",trusted="True"} 7.0
# HELP pkg_auto_removable Auto-removable packages per origin
# TYPE pkg_auto_removable gauge
pkg_auto_removable{archive="focal-updates",component="main",label="Ubuntu",origin="Ubuntu",site="ftp.fau.de",trusted="True"} 6.0
# HELP pkg_broken Broken packages per origin
# TYPE pkg_broken gauge
pkg_broken{archive="focal-updates",component="main",label="Ubuntu",origin="Ubuntu",site="ftp.fau.de",trusted="True"} 0.0

Contributing

Feel free to contribute improvements, as well as support for non-apt based systems.

Installation

Global pip installation

Run pip3 install pkg-exporter.

Install from source

Clone the repository and run poetry install from the main directory. You can also use other standard installation methods for python packages, like directly installing from this git repository.

The pyinstaller-based binary is not provided any more.

pipx

If a global pip installation is not possible (e.g. from debian 12 onwards), you can use pipx, either for install, and/or for running pkg-exporter ad hoc:

pipx run --system-site-packages pkg-exporter

--system-site-packages is necessary to provide access to the system python3-apt lib.

apt-based systems

Currently, only apt-based systems are supported. python3-apt needs to be installed on the system.

Configuration and Usage

The node exporter needs to be configured for textfiles using the --collector.textfile.directory option. This exporter needs to write the exported metrics into this directory.

The default path is /var/prometheus/pkg-exporter.prom, and may be changed via the PKG_EXPORTER_FILE-Environment Variable. If the directory is not already present, it will be created by the exporter.

The command pkg_exporter provided by the package or the binary shall be executed in a appropriate interval, e.g. using cron or systemd timers. The exporter needs to be executed with appropriate privileges, which are not necessarily root privileges.

An example configuration will be provided in this repository in the future.

apt hook

To enable monitoring for apt update calls, place the file under docs/00-pve-exporter in /etc/apt/apt.conf.d on your system. It will place files under /tmp. To customize the filepath of the timestamp files, the the environment variables PKG_EXPORTER_APT_PRE_FILE & PKG_EXPORTER_APT_POST_FILE may be used. You can see the success of monitoring the apt update timestamps if the following metric is 1: pkg_update_time_available 1.0

Please not that the presence of an timestamp does not mean that all repositories were updated without issues.

Alerting

Example alerting rules will be provided in the future.

Roadmap

  • Support for other pkg managers
  • Deployment as dpkg-Packet

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

pkg_exporter-0.2.8.dev103.tar.gz (30.7 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

pkg_exporter-0.2.8.dev103-py3-none-any.whl (18.0 kB view details)

Uploaded Python 3

File details

Details for the file pkg_exporter-0.2.8.dev103.tar.gz.

File metadata

  • Download URL: pkg_exporter-0.2.8.dev103.tar.gz
  • Upload date:
  • Size: 30.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.10.2 {"installer":{"name":"uv","version":"0.10.2","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Alpine Linux","version":"3.23.3","id":null,"libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for pkg_exporter-0.2.8.dev103.tar.gz
Algorithm Hash digest
SHA256 cf4df611c3c762ea2512d486885c43c777ea7dcdf53bdc74e7639ddcf9ce211d
MD5 e4cacbcda629b6480d6a160ccd122058
BLAKE2b-256 2ac1062b976c8206fef6c78ade71948cb739f4a899c73e3b9f5595727bdb509f

See more details on using hashes here.

File details

Details for the file pkg_exporter-0.2.8.dev103-py3-none-any.whl.

File metadata

  • Download URL: pkg_exporter-0.2.8.dev103-py3-none-any.whl
  • Upload date:
  • Size: 18.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.10.2 {"installer":{"name":"uv","version":"0.10.2","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Alpine Linux","version":"3.23.3","id":null,"libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for pkg_exporter-0.2.8.dev103-py3-none-any.whl
Algorithm Hash digest
SHA256 f83dd1252d546eb813531667e41292c650fc7dc3a32eaea200e3af9c31d5a6fd
MD5 d7dd91382d60e2ef5f18411fbce52f0f
BLAKE2b-256 0ffbb5ca8c0fdda79331b3f430fa98c4b14ba09206a824d8756a211da5212493

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