Exporting metrics from the PurpleAir API for your PurpleAir Sensor.
This is where a link to the latest relase will go.
- Description
- Technical Details
- Building Purple Exporter
- Required Configuration
- Running Purple Exporter
- Grafana
- Testing
- License
- References
purple_exporter is a Prometheus exporter that exports a subset of available information from a single PAII Purple Air Sensor.
This project was developed so I could pipe the information from my own PAII sensor to a grafana chart I run in my house. In the future, I may expand the usability of this exporter to other PA sensors, or ranges of sensors.
Metrics are collected from all sensors for which they are available.
- Humidity: Relative humidity in the sensor chamber, on average, 4% lower than ambient humidity
- Temperature: Temperature in the sensor chamber in Farenheit, on average 8F higher than ambient temperature
- Air Pressure: Current pressure in millibars
- pm1.0: Estimated mass concentration of particles less than 1 uM in diameter. (ug/m^3)
- pm2.5: Estimated mass concentration of particles less than 2.5 uM in diameter. (ug/m^3)
- pm10.0: Estimated mass concentration of particles less than 10.0 uM in diameter. (ug/m^3)
- 0.3um: Count of particles greater than 0.3 uM in diameter. (particles/100mL)
- 0.5um: Count of particles greater than 0.5 uM in diameter. (particles/100mL)
- 1.0um: Count of particles greater than 1.0 uM in diameter. (particles/100mL)
- 2.5um: Count of particles greater than 2.5 uM in diameter. (particles/100mL)
- 5.0um: Count of particles greater than 5.0 uM in diameter. (particles/100mL)
- 10.0um: Count of particles greater than 10.0 uM in diameter. (particles/100mL)
In order to use the exporter, one will need a PurpleAir API key. This can be obtained by e-mailing [email protected]. Approved applications will receive a read key, and a write key. This exporter only makes use of the read key to retrieve information from the specified sensor.
cargo build --release
The resulting executable will be placed in <path_to_repo>/target/release/
.
If running from the repository root:
docker build -t <tag> .
This will result in a trimmed down alpine linux image with a statically compiled executable.
The exporter is configurable using the values below, specified via environmental variable, or command line argument.
Set with the SENSOR_ID
environment variable, or the -s
flag.
This value is the unique index assigned by PurpleAir to the sensor that readings
will be drawn from.
Set with the READ_KEY
environment variable, or the -x
flag.
This is one of the two API keys PurpleAir will furnish when following the above
directions.
Set with the REQUEST_RATE
environment variable, or the -r
flag.
This is how often to query the purple air API, in seconds. This will
default to a minimum of once every 300 seconds (5 minutes).
Set with the PORT
environment variable, or the -p
flag.
This is the network port the exporter will serve its data from.
Set with the ADJUST
environment variable, or the -a
flag.
This flag is used to indicate whether humidity and temperature readings
should be adjusted to reflect likely ambient readings rather than readings in
the sensor housing. Sensor readings are, on average, 8F hotter and 4% drier.
Valid values are true
or false
, and will default to false
.
Set with RUST_LOG
to indicate which level of messages to log when running
purple_exporter. Options include: info
or trace
.
cargo run -- -r rate -s sensor_index -x API_read_key -p port -a adjust
./purple_exporter -r rate -s sensor_index -x API_read_key -p port -a adjust
or by setting environment variables.
docker run --env-file .env <image>
An example environment variable file is provided in .env.example
.
A Grafana dashboard for use with this exporter is available from the Grafana community library.
For direct importing into a Grafana instance, please use the packaged dashboard.json.
Work in Progress
- PurpleAir API docs
- Purple_Exporter makes use of seanmonstar's pretty-env-logger to provide activity logging.