The Skunkworks projects at the GCARC clubhouse encompass about a dozen Raspberry Pi computers along with several Linux virtual machines running on the Skunkworks server. Monitoring all of these systems is a considerable task, so we developed a simple reporting structure that allowed multiple systems to be monitored easily on a Grafana dashboard backed up by Influx databases and some Python code.
data:image/s3,"s3://crabby-images/258e1/258e165e483575b2fa0d100bdaeac9f0c91134ec" alt=""
On each system a small Python program runs each minute using system calls to determine various operating characteristics (available disk space, CPU and memory usage, etc.) . Those programs write to a central database Influx on the system monitor Pi. A Grafana dashboard server runs on that Pi and serves up those metrics in an organized format,
data:image/s3,"s3://crabby-images/b331c/b331c1ff5e1cef051fc8fc177ead4c288a1f3123" alt=""
data:image/s3,"s3://crabby-images/bcf3b/bcf3be45aa12a2d180a6b5de4fa99973c4ea7dc0" alt=""