mqtt-exporter


Namemqtt-exporter JSON
Version 1.6.0 PyPI version JSON
download
home_pageNone
SummarySimple generic MQTT Prometheus exporter for IoT working out of the box
upload_time2025-01-09 19:03:43
maintainerNone
docs_urlNone
authorNone
requires_pythonNone
licenseMIT License
keywords iot mqtt prometheus
VCS
bugtrack_url
requirements No requirements were recorded.
Travis-CI No Travis.
coveralls test coverage No coveralls.
            ![CI](https://github.com/kpetremann/mqtt-exporter/actions/workflows/ci.yml/badge.svg)
[![Codacy Badge](https://api.codacy.com/project/badge/Grade/b1ca990b576342a48d771d472e64bc24)](https://www.codacy.com/app/kpetremann/mqtt-exporter?utm_source=github.com&utm_medium=referral&utm_content=kpetremann/mqtt-exporter&utm_campaign=Badge_Grade)
[![Maintainability](https://api.codeclimate.com/v1/badges/635c98a1b4701d1ab4cf/maintainability)](https://codeclimate.com/github/kpetremann/mqtt-exporter/maintainability)
[![Code style: black](https://img.shields.io/badge/code%20style-black-000000.svg)](https://github.com/psf/black)
[![License: MIT](https://img.shields.io/badge/License-MIT-yellow.svg)](https://opensource.org/licenses/MIT)

[![Build and publish docker images](https://github.com/kpetremann/mqtt-exporter/actions/workflows/release.yml/badge.svg)](https://hub.docker.com/r/kpetrem/mqtt-exporter)

# MQTT-exporter

## Description

Simple and generic Prometheus exporter for MQTT.
Tested with Mosquitto MQTT and Xiaomi sensors.

It exposes metrics from MQTT message out of the box. You just need to specify the target if not on localhost.

MQTT-exporter expects a topic and a flat JSON payload, the value must be numeric values.

It also provides message counters for each MQTT topic:
```
mqtt_message_total{instance="mqtt-exporter:9000", job="mqtt-exporter", topic="zigbee2mqtt_0x00157d00032b1234"} 10
```

### Tested devices

Note: This exporter aims to be as generic as possible. If the sensor you use is using the following format, it will work:
```
topic '<prefix>/<name>', payload '{"temperature":26.24,"humidity":45.37}'
```

Also, the Shelly format is supported:
```
topic '<prefix>/<name>/sensor/temperature' '20.00'
```

The exporter is tested with:
  * Aqara/Xiaomi sensors (WSDCGQ11LM and VOCKQJK11LM)
  * SONOFF sensors (SNZB-02)
  * Shelly sensors (H&T wifi)
  * Shelly power sensors (3EM - only with `KEEP_FULL_TOPIC` enabled)

It is also being used by users on:
  * https://github.com/jomjol/AI-on-the-edge-device
  * https://github.com/kbialek/deye-inverter-mqtt

### Metrics conversion example
```
topic 'zigbee2mqtt/0x00157d00032b1234', payload '{"temperature":26.24,"humidity":45.37}'
```
will be converted as:
```
mqtt_temperature{topic="zigbee2mqtt_0x00157d00032b1234"} 25.24
mqtt_humidity{topic="zigbee2mqtt_0x00157d00032b1234"} 45.37
```

### Zigbee2MQTT device availability support

**Important notice: legacy availability payload is not supported and must be disabled** - see [Device availability advanced](https://www.zigbee2mqtt.io/guide/configuration/device-availability.html#availability-payload)

When exposing device availability, Zigbee2MQTT add /availability suffix in the topic. So we end up with inconsistent metrics:

```
mqtt_state{topic="zigbee2mqtt_garage_availability"} 1.0
mqtt_temperature{topic="zigbee2mqtt_garage"} 1.0
```

To avoid having different topics for the same device, the exporter has a normalization feature disabled by default.
It can be enabled by setting ZIGBEE2MQTT_AVAILABILITY varenv to "True".

It will remove the suffix from the topic and change the metric name accordingly:

```
mqtt_zigbee_availability{topic="zigbee2mqtt_garage"} 1.0
mqtt_temperature{topic="zigbee2mqtt_garage"} 1.0
```

Note: the metric name mqtt_state is not kept reducing collision risks as it is too common.

### Zwavejs2Mqtt

This exporter also supports Zwavejs2Mqtt metrics, preferably using "named topics" (see [official documentation](https://zwave-js.github.io/zwavejs2mqtt/#/usage/setup?id=gateway)).

To set up this, you need to specify the topic prefix used by Zwavejs2Mqtt in `ZWAVE_TOPIC_PREFIX` the environment variable (default being "zwave/").

### ESPHome

ESPHome is supported only when using the default `state_topic`: `<TOPIC_PREFIX>/<COMPONENT_TYPE>/<COMPONENT_NAME>/state`. (see [official documentation](https://esphome.io/components/mqtt.html#mqtt-component-base-configuration)).

To set up this, you need to specify the topic prefix list used by ESPHome in `ESPHOME_TOPIC_PREFIXES` the environment variable (default being "", so disabled).

This is a list so you can simply set one or more topic prefixes, the separator being a comma.

Example: `ESPHOME_TOPIC_PREFIXES="esphome-weather-indoor,esphome-weather-outdoor"`

If all of your ESPHome topics share a same prefix, you can simply put the common part. In the above example, `"esphome"` will match all topic starting by "esphome".

### Hubitat

Hubitat is supported. By default all topic starting with `hubitat/` will be identified and parsed as Hubitat messages.

Topics look like `hubitat/<hubname>/<device>/attributes/<attribute>/value`.

Like for ESPHome, `HUBITAT_TOPIC_PREFIXES` is a list with `,` as a separator.

### Configuration

Parameters are passed using environment variables.

The list of parameters are:
  * `KEEP_FULL_TOPIC`: Keep entire topic instead of the first two elements only. Usecase: Shelly 3EM (default: False)
  * `LOG_LEVEL`: Logging level (default: INFO)
  * `LOG_MQTT_MESSAGE`: Log MQTT original message, only if LOG_LEVEL is set to DEBUG (default: False)
  * `MQTT_IGNORED_TOPICS`: Comma-separated lists of topics to ignore. Accepts wildcards. (default: None)
  * `MQTT_ADDRESS`: IP or hostname of MQTT broker (default: 127.0.0.1)
  * `MQTT_PORT`: TCP port of MQTT broker (default: 1883)
  * `MQTT_TOPIC`: Topic path to subscribe to (default: #)
  * `MQTT_KEEPALIVE`: Keep alive interval to maintain connection with MQTT broker (default: 60)
  * `MQTT_USERNAME`: Username which should be used to authenticate against the MQTT broker (default: None)
  * `MQTT_PASSWORD`: Password which should be used to authenticate against the MQTT broker (default: None)
  * `MQTT_V5_PROTOCOL`: Force to use MQTT protocol v5 instead of 3.1.1
  * `MQTT_CLIENT_ID`: Set client ID manually for MQTT connection
  * `MQTT_EXPOSE_CLIENT_ID`: Expose the client ID as a label in Prometheus metrics
  * `PROMETHEUS_ADDRESS`: HTTP server address to expose Prometheus metrics on (default: 0.0.0.0)
  * `PROMETHEUS_PORT`: HTTP server PORT to expose Prometheus metrics (default: 9000)
  * `PROMETHEUS_PREFIX`: Prefix added to the metric name, example: mqtt_temperature (default: mqtt_)
  * `TOPIC_LABEL`: Define the Prometheus label for the topic, example temperature{topic="device1"} (default: topic)
  * `ZIGBEE2MQTT_AVAILABILITY`: Normalize sensor name for device availability metric added by Zigbee2MQTT (default: False)
  * `ZWAVE_TOPIC_PREFIX`: MQTT topic used for Zwavejs2Mqtt messages (default: zwave/)
  * `ESPHOME_TOPIC_PREFIXES`: MQTT topic used for ESPHome messages (default: "")
  * `HUBITAT_TOPIC_PREFIXES`: MQTT topic used for Hubitat messages (default: "hubitat/")
  * `EXPOSE_LAST_SEEN`: Enable additional gauges exposing last seen timestamp for each metrics

### Deployment

#### Using Docker

With an interactive shell:

```shell
docker run -it -p 9000:9000 -e "MQTT_ADDRESS=192.168.0.1" kpetrem/mqtt-exporter
```

If you need the container to start on system boot (e.g. on your server/Raspberry Pi):

```shell
docker run -d -p 9000:9000 --restart unless-stopped --name mqtt-exporter  -e "MQTT_ADDRESS=192.168.0.1" kpetrem/mqtt-exporter
```

#### Using Docker Compose

```yaml
version: "3"
services:
  mqtt-exporter:
    image: kpetrem/mqtt-exporter
    ports:
      - 9000:9000
    environment:
      - MQTT_ADDRESS=192.168.0.1
    restart: unless-stopped
```

#### Using Python

```
pip install -r requirements/base.txt
MQTT_ADDRESS=192.168.0.1 python exporter.py
```

#### Get the metrics on Prometheus

See below an example of Prometheus configuration to scrape the metrics:

```
scrape_configs:
  - job_name: mqtt-exporter
    static_configs:
      - targets: ["mqtt-exporter:9000"]
```

#### Nicer metrics

If you want nicer metrics, you can configure mqtt-exporter in your `docker-compose.yml` as followed:
```
version: "3"
services:
  mqtt-exporter:
    image: kpetrem/mqtt-exporter
    ports:
      - 9000:9000
    environment:
      - MQTT_ADDRESS=192.168.0.1
      - PROMETHEUS_PREFIX=sensor_
      - TOPIC_LABEL=sensor
    restart: unless-stopped
```

Result:
```
sensor_temperature{sensor="zigbee2mqtt_bedroom"} 22.3
```

And then remove `zigbee2mqtt_` prefix from `sensor` label via Prometheus configuration:

```
scrape_configs:
  - job_name: mqtt-exporter
    static_configs:
      - targets: ["mqtt-exporter:9000"]
    metric_relabel_configs:
      - source_labels: [sensor]
        regex: 'zigbee2mqtt_(.*)'
        replacement: '$1'
        target_label: sensor
```

Result:
```
sensor_temperature{sensor=bedroom"} 22.3
```

## Docker-compose full stack example

This docker-compose aims to share a typical monitoring stack.

If you need persistent metrics, I would advise using VictoriaMetrics. Of course there are other suitable persistent storage solutions for Prometheus.

[docker-compose.yaml](https://github.com/kpetremann/mqtt-exporter/blob/master/doc/example/docker-compose.yml)

You can also add other cool software such as Home-Assistant.

## CLI interactive test

You can use the test mode to preview the conversion of a topic and payload to Prometheus metrics.

Usage example:

```
$ python ./exporter.py --test
topic: zigbee2mqtt/0x00157d00032b1234
payload: {"temperature":26.24,"humidity":45.37}

## Debug ##

parsed to: zigbee2mqtt_0x00157d00032b1234 {'temperature': 26.24, 'humidity': 45.37}
INFO:mqtt-exporter:creating prometheus metric: PromMetricId(name='mqtt_temperature', labels=())
INFO:mqtt-exporter:creating prometheus metric: PromMetricId(name='mqtt_humidity', labels=())

## Result ##

# HELP mqtt_temperature metric generated from MQTT message.
# TYPE mqtt_temperature gauge
mqtt_temperature{topic="zigbee2mqtt_0x00157d00032b1234"} 26.24
# HELP mqtt_humidity metric generated from MQTT message.
# TYPE mqtt_humidity gauge
mqtt_humidity{topic="zigbee2mqtt_0x00157d00032b1234"} 45.37
```

## Contribute

See [CONTRIBUTING.md](./CONTRIBUTING.md).

### Support

If you like my work, don't hesitate to buy me a coffee :)

<a href="https://www.buymeacoffee.com/kpetremann" target="_blank"><img src="https://cdn.buymeacoffee.com/buttons/v2/default-yellow.png" alt="Buy Me A Coffee" style="height: 60px !important;width: 217px !important;" ></a>

[![](https://img.shields.io/static/v1?label=Sponsor&message=%E2%9D%A4&logo=GitHub&color=%23fe8e86)](https://github.com/sponsors/kpetremann)

            

Raw data

            {
    "_id": null,
    "home_page": null,
    "name": "mqtt-exporter",
    "maintainer": null,
    "docs_url": null,
    "requires_python": null,
    "maintainer_email": null,
    "keywords": "iot, mqtt, prometheus",
    "author": null,
    "author_email": "Kevin Petremann <kpetrem@gmail.com>",
    "download_url": "https://files.pythonhosted.org/packages/7e/01/53a397358a8a8e15cde0e303e3b6e20d894e7b61099e15456a03399290fe/mqtt_exporter-1.6.0.tar.gz",
    "platform": null,
    "description": "![CI](https://github.com/kpetremann/mqtt-exporter/actions/workflows/ci.yml/badge.svg)\n[![Codacy Badge](https://api.codacy.com/project/badge/Grade/b1ca990b576342a48d771d472e64bc24)](https://www.codacy.com/app/kpetremann/mqtt-exporter?utm_source=github.com&amp;utm_medium=referral&amp;utm_content=kpetremann/mqtt-exporter&amp;utm_campaign=Badge_Grade)\n[![Maintainability](https://api.codeclimate.com/v1/badges/635c98a1b4701d1ab4cf/maintainability)](https://codeclimate.com/github/kpetremann/mqtt-exporter/maintainability)\n[![Code style: black](https://img.shields.io/badge/code%20style-black-000000.svg)](https://github.com/psf/black)\n[![License: MIT](https://img.shields.io/badge/License-MIT-yellow.svg)](https://opensource.org/licenses/MIT)\n\n[![Build and publish docker images](https://github.com/kpetremann/mqtt-exporter/actions/workflows/release.yml/badge.svg)](https://hub.docker.com/r/kpetrem/mqtt-exporter)\n\n# MQTT-exporter\n\n## Description\n\nSimple and generic Prometheus exporter for MQTT.\nTested with Mosquitto MQTT and Xiaomi sensors.\n\nIt exposes metrics from MQTT message out of the box. You just need to specify the target if not on localhost.\n\nMQTT-exporter expects a topic and a flat JSON payload, the value must be numeric values.\n\nIt also provides message counters for each MQTT topic:\n```\nmqtt_message_total{instance=\"mqtt-exporter:9000\", job=\"mqtt-exporter\", topic=\"zigbee2mqtt_0x00157d00032b1234\"} 10\n```\n\n### Tested devices\n\nNote: This exporter aims to be as generic as possible. If the sensor you use is using the following format, it will work:\n```\ntopic '<prefix>/<name>', payload '{\"temperature\":26.24,\"humidity\":45.37}'\n```\n\nAlso, the Shelly format is supported:\n```\ntopic '<prefix>/<name>/sensor/temperature' '20.00'\n```\n\nThe exporter is tested with:\n  * Aqara/Xiaomi sensors (WSDCGQ11LM and VOCKQJK11LM)\n  * SONOFF sensors (SNZB-02)\n  * Shelly sensors (H&T wifi)\n  * Shelly power sensors (3EM - only with `KEEP_FULL_TOPIC` enabled)\n\nIt is also being used by users on:\n  * https://github.com/jomjol/AI-on-the-edge-device\n  * https://github.com/kbialek/deye-inverter-mqtt\n\n### Metrics conversion example\n```\ntopic 'zigbee2mqtt/0x00157d00032b1234', payload '{\"temperature\":26.24,\"humidity\":45.37}'\n```\nwill be converted as:\n```\nmqtt_temperature{topic=\"zigbee2mqtt_0x00157d00032b1234\"} 25.24\nmqtt_humidity{topic=\"zigbee2mqtt_0x00157d00032b1234\"} 45.37\n```\n\n### Zigbee2MQTT device availability support\n\n**Important notice: legacy availability payload is not supported and must be disabled** - see [Device availability advanced](https://www.zigbee2mqtt.io/guide/configuration/device-availability.html#availability-payload)\n\nWhen exposing device availability, Zigbee2MQTT add /availability suffix in the topic. So we end up with inconsistent metrics:\n\n```\nmqtt_state{topic=\"zigbee2mqtt_garage_availability\"} 1.0\nmqtt_temperature{topic=\"zigbee2mqtt_garage\"} 1.0\n```\n\nTo avoid having different topics for the same device, the exporter has a normalization feature disabled by default.\nIt can be enabled by setting ZIGBEE2MQTT_AVAILABILITY varenv to \"True\".\n\nIt will remove the suffix from the topic and change the metric name accordingly:\n\n```\nmqtt_zigbee_availability{topic=\"zigbee2mqtt_garage\"} 1.0\nmqtt_temperature{topic=\"zigbee2mqtt_garage\"} 1.0\n```\n\nNote: the metric name mqtt_state is not kept reducing collision risks as it is too common.\n\n### Zwavejs2Mqtt\n\nThis exporter also supports Zwavejs2Mqtt metrics, preferably using \"named topics\" (see [official documentation](https://zwave-js.github.io/zwavejs2mqtt/#/usage/setup?id=gateway)).\n\nTo set up this, you need to specify the topic prefix used by Zwavejs2Mqtt in `ZWAVE_TOPIC_PREFIX` the environment variable (default being \"zwave/\").\n\n### ESPHome\n\nESPHome is supported only when using the default `state_topic`: `<TOPIC_PREFIX>/<COMPONENT_TYPE>/<COMPONENT_NAME>/state`. (see [official documentation](https://esphome.io/components/mqtt.html#mqtt-component-base-configuration)).\n\nTo set up this, you need to specify the topic prefix list used by ESPHome in `ESPHOME_TOPIC_PREFIXES` the environment variable (default being \"\", so disabled).\n\nThis is a list so you can simply set one or more topic prefixes, the separator being a comma.\n\nExample: `ESPHOME_TOPIC_PREFIXES=\"esphome-weather-indoor,esphome-weather-outdoor\"`\n\nIf all of your ESPHome topics share a same prefix, you can simply put the common part. In the above example, `\"esphome\"` will match all topic starting by \"esphome\".\n\n### Hubitat\n\nHubitat is supported. By default all topic starting with `hubitat/` will be identified and parsed as Hubitat messages.\n\nTopics look like `hubitat/<hubname>/<device>/attributes/<attribute>/value`.\n\nLike for ESPHome, `HUBITAT_TOPIC_PREFIXES` is a list with `,` as a separator.\n\n### Configuration\n\nParameters are passed using environment variables.\n\nThe list of parameters are:\n  * `KEEP_FULL_TOPIC`: Keep entire topic instead of the first two elements only. Usecase: Shelly 3EM (default: False)\n  * `LOG_LEVEL`: Logging level (default: INFO)\n  * `LOG_MQTT_MESSAGE`: Log MQTT original message, only if LOG_LEVEL is set to DEBUG (default: False)\n  * `MQTT_IGNORED_TOPICS`: Comma-separated lists of topics to ignore. Accepts wildcards. (default: None)\n  * `MQTT_ADDRESS`: IP or hostname of MQTT broker (default: 127.0.0.1)\n  * `MQTT_PORT`: TCP port of MQTT broker (default: 1883)\n  * `MQTT_TOPIC`: Topic path to subscribe to (default: #)\n  * `MQTT_KEEPALIVE`: Keep alive interval to maintain connection with MQTT broker (default: 60)\n  * `MQTT_USERNAME`: Username which should be used to authenticate against the MQTT broker (default: None)\n  * `MQTT_PASSWORD`: Password which should be used to authenticate against the MQTT broker (default: None)\n  * `MQTT_V5_PROTOCOL`: Force to use MQTT protocol v5 instead of 3.1.1\n  * `MQTT_CLIENT_ID`: Set client ID manually for MQTT connection\n  * `MQTT_EXPOSE_CLIENT_ID`: Expose the client ID as a label in Prometheus metrics\n  * `PROMETHEUS_ADDRESS`: HTTP server address to expose Prometheus metrics on (default: 0.0.0.0)\n  * `PROMETHEUS_PORT`: HTTP server PORT to expose Prometheus metrics (default: 9000)\n  * `PROMETHEUS_PREFIX`: Prefix added to the metric name, example: mqtt_temperature (default: mqtt_)\n  * `TOPIC_LABEL`: Define the Prometheus label for the topic, example temperature{topic=\"device1\"} (default: topic)\n  * `ZIGBEE2MQTT_AVAILABILITY`: Normalize sensor name for device availability metric added by Zigbee2MQTT (default: False)\n  * `ZWAVE_TOPIC_PREFIX`: MQTT topic used for Zwavejs2Mqtt messages (default: zwave/)\n  * `ESPHOME_TOPIC_PREFIXES`: MQTT topic used for ESPHome messages (default: \"\")\n  * `HUBITAT_TOPIC_PREFIXES`: MQTT topic used for Hubitat messages (default: \"hubitat/\")\n  * `EXPOSE_LAST_SEEN`: Enable additional gauges exposing last seen timestamp for each metrics\n\n### Deployment\n\n#### Using Docker\n\nWith an interactive shell:\n\n```shell\ndocker run -it -p 9000:9000 -e \"MQTT_ADDRESS=192.168.0.1\" kpetrem/mqtt-exporter\n```\n\nIf you need the container to start on system boot (e.g. on your server/Raspberry Pi):\n\n```shell\ndocker run -d -p 9000:9000 --restart unless-stopped --name mqtt-exporter  -e \"MQTT_ADDRESS=192.168.0.1\" kpetrem/mqtt-exporter\n```\n\n#### Using Docker Compose\n\n```yaml\nversion: \"3\"\nservices:\n  mqtt-exporter:\n    image: kpetrem/mqtt-exporter\n    ports:\n      - 9000:9000\n    environment:\n      - MQTT_ADDRESS=192.168.0.1\n    restart: unless-stopped\n```\n\n#### Using Python\n\n```\npip install -r requirements/base.txt\nMQTT_ADDRESS=192.168.0.1 python exporter.py\n```\n\n#### Get the metrics on Prometheus\n\nSee below an example of Prometheus configuration to scrape the metrics:\n\n```\nscrape_configs:\n  - job_name: mqtt-exporter\n    static_configs:\n      - targets: [\"mqtt-exporter:9000\"]\n```\n\n#### Nicer metrics\n\nIf you want nicer metrics, you can configure mqtt-exporter in your `docker-compose.yml` as followed:\n```\nversion: \"3\"\nservices:\n  mqtt-exporter:\n    image: kpetrem/mqtt-exporter\n    ports:\n      - 9000:9000\n    environment:\n      - MQTT_ADDRESS=192.168.0.1\n      - PROMETHEUS_PREFIX=sensor_\n      - TOPIC_LABEL=sensor\n    restart: unless-stopped\n```\n\nResult:\n```\nsensor_temperature{sensor=\"zigbee2mqtt_bedroom\"} 22.3\n```\n\nAnd then remove `zigbee2mqtt_` prefix from `sensor` label via Prometheus configuration:\n\n```\nscrape_configs:\n  - job_name: mqtt-exporter\n    static_configs:\n      - targets: [\"mqtt-exporter:9000\"]\n    metric_relabel_configs:\n      - source_labels: [sensor]\n        regex: 'zigbee2mqtt_(.*)'\n        replacement: '$1'\n        target_label: sensor\n```\n\nResult:\n```\nsensor_temperature{sensor=bedroom\"} 22.3\n```\n\n## Docker-compose full stack example\n\nThis docker-compose aims to share a typical monitoring stack.\n\nIf you need persistent metrics, I would advise using VictoriaMetrics. Of course there are other suitable persistent storage solutions for Prometheus.\n\n[docker-compose.yaml](https://github.com/kpetremann/mqtt-exporter/blob/master/doc/example/docker-compose.yml)\n\nYou can also add other cool software such as Home-Assistant.\n\n## CLI interactive test\n\nYou can use the test mode to preview the conversion of a topic and payload to Prometheus metrics.\n\nUsage example:\n\n```\n$ python ./exporter.py --test\ntopic: zigbee2mqtt/0x00157d00032b1234\npayload: {\"temperature\":26.24,\"humidity\":45.37}\n\n## Debug ##\n\nparsed to: zigbee2mqtt_0x00157d00032b1234 {'temperature': 26.24, 'humidity': 45.37}\nINFO:mqtt-exporter:creating prometheus metric: PromMetricId(name='mqtt_temperature', labels=())\nINFO:mqtt-exporter:creating prometheus metric: PromMetricId(name='mqtt_humidity', labels=())\n\n## Result ##\n\n# HELP mqtt_temperature metric generated from MQTT message.\n# TYPE mqtt_temperature gauge\nmqtt_temperature{topic=\"zigbee2mqtt_0x00157d00032b1234\"} 26.24\n# HELP mqtt_humidity metric generated from MQTT message.\n# TYPE mqtt_humidity gauge\nmqtt_humidity{topic=\"zigbee2mqtt_0x00157d00032b1234\"} 45.37\n```\n\n## Contribute\n\nSee [CONTRIBUTING.md](./CONTRIBUTING.md).\n\n### Support\n\nIf you like my work, don't hesitate to buy me a coffee :)\n\n<a href=\"https://www.buymeacoffee.com/kpetremann\" target=\"_blank\"><img src=\"https://cdn.buymeacoffee.com/buttons/v2/default-yellow.png\" alt=\"Buy Me A Coffee\" style=\"height: 60px !important;width: 217px !important;\" ></a>\n\n[![](https://img.shields.io/static/v1?label=Sponsor&message=%E2%9D%A4&logo=GitHub&color=%23fe8e86)](https://github.com/sponsors/kpetremann)\n",
    "bugtrack_url": null,
    "license": "MIT License",
    "summary": "Simple generic MQTT Prometheus exporter for IoT working out of the box",
    "version": "1.6.0",
    "project_urls": {
        "Homepage": "https://github.com/kpetremann/mqtt-exporter"
    },
    "split_keywords": [
        "iot",
        " mqtt",
        " prometheus"
    ],
    "urls": [
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "773c3aa3d7e6fa8a24483565e511d9fde2924d519b27b6aae1522f645c19c3ae",
                "md5": "89bb3036e1e0dd8c22c8f9624e3237b5",
                "sha256": "b65d0d4986b2f5f63892e4c76420b9be0264da21e1868ec8e590322d8d09a801"
            },
            "downloads": -1,
            "filename": "mqtt_exporter-1.6.0-py3-none-any.whl",
            "has_sig": false,
            "md5_digest": "89bb3036e1e0dd8c22c8f9624e3237b5",
            "packagetype": "bdist_wheel",
            "python_version": "py3",
            "requires_python": null,
            "size": 12249,
            "upload_time": "2025-01-09T19:03:38",
            "upload_time_iso_8601": "2025-01-09T19:03:38.276187Z",
            "url": "https://files.pythonhosted.org/packages/77/3c/3aa3d7e6fa8a24483565e511d9fde2924d519b27b6aae1522f645c19c3ae/mqtt_exporter-1.6.0-py3-none-any.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "7e0153a397358a8a8e15cde0e303e3b6e20d894e7b61099e15456a03399290fe",
                "md5": "4011f8ca2095b83966dc2f5bfe791eef",
                "sha256": "8d6a41e3875e35f2f204a61f97e6b43990bb1acbe88edc66112c7a06283be7ef"
            },
            "downloads": -1,
            "filename": "mqtt_exporter-1.6.0.tar.gz",
            "has_sig": false,
            "md5_digest": "4011f8ca2095b83966dc2f5bfe791eef",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": null,
            "size": 15677,
            "upload_time": "2025-01-09T19:03:43",
            "upload_time_iso_8601": "2025-01-09T19:03:43.166223Z",
            "url": "https://files.pythonhosted.org/packages/7e/01/53a397358a8a8e15cde0e303e3b6e20d894e7b61099e15456a03399290fe/mqtt_exporter-1.6.0.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2025-01-09 19:03:43",
    "github": true,
    "gitlab": false,
    "bitbucket": false,
    "codeberg": false,
    "github_user": "kpetremann",
    "github_project": "mqtt-exporter",
    "travis_ci": false,
    "coveralls": false,
    "github_actions": true,
    "lcname": "mqtt-exporter"
}
        
Elapsed time: 0.45186s