Allows for importing data from IQAir to InfluxDB v2.
- An IQAir API Key.
- A device with either Docker or Python 3.7 or later installed.
- InfluxDB v2 installed on this device or another device, and a bucket created in influxDB.
Dependency: Docker installed.
- Download and run the Docker image:
sudo docker run --name iqair -v config.yaml:/app/config.yaml vdbg/iqair-influx:latest
- Copy the template config file from the image:
sudo docker cp iqair:/app/template.config.yaml config.yaml
- Edit
config.yaml
by following the instructions in the file - Start the container again to verify the settings are correct:
sudo docker start iqair -i
- Once the settings are finalized,
Ctrl-C
to stop the container,sudo docker container rm iqair
to delete it - Start the container with the final settings:
sudo docker run \ -d \ --name iqair \ -v /path_to_your/config.yaml:/app/config.yaml \ --memory=100m \ --pull=always \ --restart=always \ vdbg/iqair-influx:latest
Dependency: Python3 and pip3 installed. sudo apt-get install python3-pip
if missing on raspbian.
- Git clone this repository and cd into directory
cp template.config.yaml config.yaml
- Edit file
config.yaml
by following the instructions in the file pip3 install -r requirements.txt
python3 main.py
or./main.py
Although this isn't documented on IQAir's plan comparison page, it appears that with the free plan the data is only refreshed once per hour. Since InfluxDB automatically de-dupes identical measurements, this means only two measurements (one weather, one pollution) per hour will end up showing up in the bucket.
The app makes one call per location, which can be affected by the throttling restrictions of the free plan:
- 5 requests per minute max: to query more than 5 locations, two options:
- create one docker container per group of 5 locations and start all containers at least one minute apart.
- specify more than one apiKey in
config.yaml
. The script will randomly choose one for each request.
- 10,000 requests per month max: for a month of 31 days, this means no more than 1 request every ~5 minutes for 1 location (10 minutes for 2 locations, 15m for 3, etc) if continuously running. Options:
- don't continuously query; for example, stop querying during the night
- specify more than one apiKey in
config.yaml
.
- There appears to be an undocumented per year limit. My API keys end up being permanently rejected around November, even when not issuing queries for several days.
The US and CN threseholds are both listed on Wikipedia.
This template is what produced the following Grafana dashboard:
Note: the dashboard uses influxdb v1 compatibility mode. This page explains how to enable it.