The first goal is to be able to display the result of the monitoring of the computer. We have a MQTT broker that is receiving information about my server every 10s. We should create everything required to display chart for the monitoring.
After installing mosquitto
you can check the packets using mosquitto_sub -h mqtt.hackuarium.org -t "lpatiny/Computer/server"
Use Zakodium components
Please have a look at: #9 and try to migrate to it if possible.
Create preferences and menu
The menu on the left will depend on the available devices. So at the beginning we have only the preferences menu.
The preference menu contains 4 submenu. The next step to implement is the preferences: #7
Once we know the devices that are configured we can display in the menu the corresponding categories if there is at least one device configured.
Bioreactor (if there are some devices of category OpenBio6)
Beemos (if there are some devices of category Beemos)
Computer (if there are some devices of category Computer)
Spectrophotometer (if there are some devices of category SimpleSpectro)
As a submenu of those 4 categories we will display the custom name defined by the user in the preferences
Store / Synchronise data
First step:
There should be a background process that will take care to listen for all the MQTT packets received for the Broadcast devices.
The packet is parsed and store in a local pouchDB. I would use for the pouchDB database name the device kind + underscore + custom name. This will allow in the future to display the results for the currently configured devices as well as some historetical data for which there is a pouchDB database.
We will see laster how to synchronize interactive devices.
Display the results
Based on the preferences we fill the menu on the left. In this case there should be a menu Computer
with a submenu Luc_Cellar
(if this is the name used in the preferences).
Clicking on this submenu will bring the Computer
layout to display the results.
In the layout there will be 4 charts:
- Load
- xAxis: time
- yAxis: % from 0 to 100 (forced values)
- series: total, user, system
- I/O
- xAxis: time
- yAxis: kb / s (not sure about this per second, the format is wrong seems to me)
- series: Network read, Network write, Disk read, Disk write
- FS
- xAxis: time
- yAxis: % from 0 to 100 (forced values)
- series: min, max
- Temperature
- xAxis: time
- yAxis: °C from 0 to 100 (forced values)
- series: CPU
On the top we should be able to define if we want to display: 1h / 1d / 1m / 1y
We will see later if we need more flexibility for the date picking.