Add static sensor charts
This commit is contained in:
parent
412792eddd
commit
a26bb14b02
|
@ -1,17 +1,63 @@
|
|||
Title: Sensors
|
||||
Date: 2022-05-24
|
||||
Category: Notes
|
||||
Summary: A dashboard for various sensors around my house.
|
||||
Summary: Graphs of various sensors around my house.
|
||||
Short: d
|
||||
|
||||
I wrote a custom [dashboard](https://sensors.dns.t0.vc/) to visualize data from various sensors around my house. I'm a huge fan of sensors because they're at the intersection of what I love: electronics, home automation, and data hoarding.
|
||||
## Graphs
|
||||
|
||||
These graphs are live and updated once per minute, assuming the script works:
|
||||
|
||||
data:image/s3,"s3://crabby-images/719b5/719b51377997683c768f5de6a9d60ade66741b67" alt="a graph"
|
||||
|
||||
Black: power (W), green: energy (kWh)
|
||||
|
||||
data:image/s3,"s3://crabby-images/56614/56614284627f9cd2482dc9e2f3c1aaac812dc844" alt="a graph"
|
||||
|
||||
Black: PM10 (ug/m³), red: PM2.5 (ug/m³), blue: CO₂ (ppm), green: VOC / 500
|
||||
|
||||
data:image/s3,"s3://crabby-images/94e71/94e71cad969a52ed667b5699f4050ba494371fb3" alt="a graph"
|
||||
|
||||
Black: temperature (°C)
|
||||
|
||||
data:image/s3,"s3://crabby-images/ce47e/ce47e4fb470ddc15a677ab1c94afae314b005133" alt="a graph"
|
||||
|
||||
Black: temperature (°C), green: humidity (%)
|
||||
|
||||
data:image/s3,"s3://crabby-images/afc27/afc27f3ae43261723ef89b1618ddfd43d1169ec3" alt="a graph"
|
||||
|
||||
Black: temperature (°C), green: humidity (%)
|
||||
|
||||
data:image/s3,"s3://crabby-images/d5281/d52819bd2695bd73b1fcd7f26dabae95bd2d2585" alt="a graph"
|
||||
|
||||
Black: temperature (°C), green: humidity (%)
|
||||
|
||||
data:image/s3,"s3://crabby-images/dfe0b/dfe0b3d07ac1456014d25f54d93929fabea8c78e" alt="a graph"
|
||||
|
||||
Black: temperature (°C), red: setpoint (°C), green: state (off / heating / cooling)
|
||||
|
||||
data:image/s3,"s3://crabby-images/474e7/474e71ecbf7a9d9e47b3e9d2d9258482a8608c5b" alt="a graph"
|
||||
|
||||
Black: total (MJ), green: delta (MJ)
|
||||
|
||||
data:image/s3,"s3://crabby-images/2a0e8/2a0e857d6238c52ddc3449d94745b30443f84775" alt="a graph"
|
||||
|
||||
Black: total (L), green: delta (L)
|
||||
|
||||
data:image/s3,"s3://crabby-images/74250/7425076452a1da63e32fc072b019e10a657a5613" alt="a graph"
|
||||
|
||||
Black: light (lx)
|
||||
|
||||
## Live Dashboard
|
||||
|
||||
A live interactive version can be found on this [dashboard](https://sensors.dns.t0.vc/).
|
||||
|
||||
You can find the [source code](https://git.tannercollin.com/tanner/sensors) on my Gitea.
|
||||
|
||||
![[sensors1.png]]
|
||||
## Data Capture
|
||||
|
||||
Most of the data is captured by two cheap RTL-SDRs (software-defined radios) that are set to listen to 433 MHz and 915 MHz radio frequencies. I use the open-source project [rtl_433](https://github.com/merbanan/rtl_433) to automatically decode the signals and forward them to an MQTT broker, which is a messaging server that services can publish and subscribe to. Other sensors run an MQTT client directly or expose their data through other means like a web interface that I poll.
|
||||
|
||||
The data gets collected by a central Python script that process and stores it in an InfluxDB database for "efficient" storage. The script also runs a web server that queries the database and exposes the data over an API to the dashboard at various dates and ranges. The dashboard is written in JavaScript / React using a simple chart library.
|
||||
|
||||
My biggest regret was using InfluxDB. It's a stupid database and I wouldn't recommend it to anyone. The documentation is confusing and I ran into timezone issues with `group by time()`. It also assumes the column data type is an integer if your sensor happens to send it a whole number at first and it won't let you change that. Just stick to Postgres / SQLite.
|
||||
My biggest regret was using InfluxDB. It's a stupid database and I wouldn't recommend it to anyone. The documentation is confusing and I ran into timezone issues with `group by time()`. It also assumes the column data type is an integer if your sensor happens to send it a whole number at first and it won't let you change that. Just stick to Postgres / SQLite.
|
||||
|
|
Loading…
Reference in New Issue
Block a user