Skip to main content

Grommunio email system data exporter for Prometheus

Project description

Grommunio exporter for Prometheus

License Percentage of issues still open GitHub Release Linux linter

This program exposes Grommunio email system metrics for Prometheus
Since we already have node_exporter for system metrics and postfix_exporter for email deliverability metrics, this closes the gap with mailbox metrics.

Requirements

  • Grommunio 2.x/3.x
  • python >= 3.7

Grafana Dashboard

You can find an example dashboard in the examples directory

image image

Automatic installation

On current Grommunio appliances based on OpenSuSE, you can use the following all-in-one installer script

curl -sSfL https://raw.githubusercontent.com/netinvent/grommunio_exporter/refs/heads/main/install.sh | sh -

Manual Install

Easiest way to install grommunio_exporter is to use python pip:

python3 -m pip install grommunio_exporter

Upgrading

Upgrading can be done via following command lines

python3 -m pip install --upgrade grommunio_exporter
systemctl restart grommunio_exporter

Special notes for Grommunio appliances

Note that on Grommunio appliances based on OpenSuSE 15.6, there may be both python 3.6 and python 3.11 installed.
Best way not to mess with python's grommunio environment is to build a venv environment specific to a newer python version.

zypper install python311
python3.11 -m venv /usr/local/grommunio_exporter_venv
/usr/local/grommunio_exporter_venv/bin/python -m pip install --upgrade pip setuptools wheel
/usr/local/grommunio_exporter_venv/bin/python -m pip install grommunio_exporter

Running the exporter can be done via /usr/local/grommunio_exporter_venv/bin/grommunio_exporter. This file can be run manually for testing purposes, or run as service.

Once installed, you can create a systemd service file from the systemd unit file in the example dir.
Once the service is running, you may query the exporter with:

curl http://localhost:9769/metrics

Firewall

The default exporter-port is 9799/tcp, which you can change in the config file. Keep in mind that you need to create a firewall rule if you want to query it's output.

You can create the firewall rule with the following command on a Grommunio appliance

firewall-cmd --add-port=9799/tcp --permanent && firewall-cmd --reload

Metrics

The exporter currently produces the following metrics:

  • grommunio_api_status is 0 when no errors where found in api calls
  • grommunio_exporter_version is 0 when version successfully reported
  • grommunio_gromox_version is 0 when version successfully reported
  • grommunio_admin_version is 0 when version successfully reported
  • grommunio_mailbox_count
  • grommunio_shared_mailbox_count

The following metrics are per user and have labels hostname,domain,username:

  • grommunio_mailbox_messagesize
  • grommunio_mailbox_storage_quota_limit
  • grommunio_mailbox_prohibit_receive_limit
  • grommunio_mailbox_prohibit_send_quota
  • grommunio_mailbox_creation_time
  • grommunio_mailbox_out_of_office_state

Alert rules:

    - alert: Storage Quota
      expr: (1-((grommunio_mailbox_storage_quota_limit - grommunio_mailbox_messagesize)/grommunio_mailbox_storage_quota_limit))*100 > 95
      for: 5m

    - alert: Prohibit Send Quota
      expr: (1-((grommunio_mailbox_prohibit_send_quota - grommunio_mailbox_messagesize)/grommunio_mailbox_prohibit_send_quota))*100 > 95
      for: 5m

    - alert: Prohibit Receive Quota
      expr:  (1-((grommunio_mailbox_prohibit_receive_limit - grommunio_mailbox_messagesize)/grommunio_mailbox_prohibit_receive_limit))*100 > 95
      for: 5m

Customization

You may create a grommunio_exporter.yaml that can be added to the exporter via --config-file=/etc/grommunio_exporter.yaml argument.
This file can override the following:

  • http listen ip
  • http listen port
  • http authentication
  • grommunio hostname
  • mysql database settings

Troubleshooting

This program has currently been tested on grommunio-admin-api-1.16.8.

By default, the exporter will log to /var/log/grommunio_exporter.log
You can override this in the config file.

You may also run the exporter with --debug in order to gain more information.

You can set the following scrape settings in the prometheus job:

scrape_interval: 300s
scrape_timeout: 240s

Misc

This version of the grommunio exporter uses the locally installed grommunio-admin cli interface instead of the REST API.
Pros:

  • No need for authentication

Cons:

  • Not all commands output parseable json
  • Probably slower than REST UI

If the project gains some traction, we can add REST UI support.

License

Licensed under GPLv3.0... Contributions are welcome
(C) 2024-2025 NetInvent SASU

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

grommunio_exporter-0.7.2.tar.gz (30.9 kB view details)

Uploaded Source

Built Distribution

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

grommunio_exporter-0.7.2-py3-none-any.whl (32.4 kB view details)

Uploaded Python 3

File details

Details for the file grommunio_exporter-0.7.2.tar.gz.

File metadata

  • Download URL: grommunio_exporter-0.7.2.tar.gz
  • Upload date:
  • Size: 30.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.0.0 CPython/3.12.10

File hashes

Hashes for grommunio_exporter-0.7.2.tar.gz
Algorithm Hash digest
SHA256 f222f00184844a4ba269e58d7fc5dafe35cd3a2b803b5a65e74639d340f3ce2a
MD5 3c2d3516ff3b814ed7c951a0af957033
BLAKE2b-256 64c5ab9c1c10590e9f049ab37849ba6d41dc9a65c0a8435d3357b7246010d2e0

See more details on using hashes here.

File details

Details for the file grommunio_exporter-0.7.2-py3-none-any.whl.

File metadata

File hashes

Hashes for grommunio_exporter-0.7.2-py3-none-any.whl
Algorithm Hash digest
SHA256 28d8829557f0541da18d8536b613b462978f9eaa99c8a5d4f17c3c2d77906faf
MD5 0c0ac762dbc2c1418eda4f7fceda2c86
BLAKE2b-256 81f3943d218c2907c02a7eee3318684cc3a5ca34ebc48b5b7a8e5755d7e57349

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