STORY Dashboard
data:image/s3,"s3://crabby-images/512f8/512f85be84ad99cf36403e17bd392f0d99b33dcf" alt="Story banner"
Overview
To set up an effective node monitoring system, we’ll use three main tools:
- Prometheus: Collects and stores metrics.
- Node Exporter: Gathers metrics from the system and hardware.
- Grafana: Displays data in graphs and dashboards.
data:image/s3,"s3://crabby-images/3accf/3accfadba24582b876268893b201e43c434bc4c1" alt=""
Preview: https://story-dashboard.josephtran.xyz/ | username: user
| password: 123456
System Requirements
- Operating System: Ubuntu 20.04 LTS or newer
- RAM: Minimum 2GB
- CPU: 2 cores or more
- Disk Space: At least 20GB free
Implementation Steps
1. Installing Prometheus
Prometheus is an open-source monitoring system and time series database.
- Download and install Prometheus:
cd $HOMEwget https://github.com/prometheus/prometheus/releases/download/v2.42.0/prometheus-2.42.0.linux-amd64.tar.gztar xvf prometheus-2.42.0.linux-amd64.tar.gzsudo mkdir -p /opt/prometheussudo cp -r prometheus-2.42.0.linux-amd64/* /opt/prometheus/rm -f prometheus-2.42.0.linux-amd64.tar.gz
data:image/s3,"s3://crabby-images/8736e/8736efbf37cb33053638605b388b25f65c42c41c" alt=""
- Create Prometheus user:
sudo useradd --no-create-home --shell /bin/false prometheus
- Create necessary directories:
sudo mkdir /etc/prometheussudo mkdir /var/lib/prometheussudo touch /etc/default/prometheus
- Configure permissions:
sudo chown -R prometheus:prometheus /etc/prometheus /var/lib/prometheus /opt/prometheussudo chmod 755 /opt/prometheus/prometheus
- Create Prometheus configuration file:
sudo nano /etc/prometheus/prometheus.yml
- Insert Prometheus configuration content:
# Sample config for Prometheus.
global: scrape_interval: 15s # Set the scrape interval to every 15 seconds. Default is every 1 minute. evaluation_interval: 15s # Evaluate rules every 15 seconds. The default is every 1 minute. # scrape_timeout is set to the global default (10s).
# Attach these labels to any time series or alerts when communicating with# external systems (federation, remote storage, Alertmanager).
# Alertmanager configurationalerting: alertmanagers: - static_configs: - targets: ['localhost:9093']
# Load rules once and periodically evaluate them according to the global 'evaluation_interval'.rule_files: # - "first_rules.yml" # - "second_rules.yml"
# A scrape configuration containing exactly one endpoint to scrape:# Here it's Prometheus itself.scrape_configs: # The job name is added as a label `job=<job_name>` to any timeseries scraped from this config. - job_name: 'prometheus'
# Override the global default and scrape targets from this job every 5 seconds. scrape_interval: 5s scrape_timeout: 5s
# metrics_path defaults to '/metrics' # scheme defaults to 'http'.
static_configs: - targets: ['localhost:9090']
- job_name: node-exporter # If prometheus-node-exporter is installed, grab stats about the local # machine by default. static_configs: - targets: ['PUBLIC_SERVER_IP:9200']
- job_name: 'Story' static_configs: - targets: ['PUBLIC_SERVER_IP:26660']
data:image/s3,"s3://crabby-images/de6a9/de6a9c99664dd8cfcda9c5250e1ad86d633f609c" alt=""
- Explain config:
- job_name: 'Story' static_configs: - targets: ['PUBLIC_SERVER_IP:26660']
- For config this port
PUBLIC_SERVER_IP:26660
you have to edit file at$HOME/.story/story/config/config.toml
and Restart Story node
data:image/s3,"s3://crabby-images/ff28c/ff28c1337778ebb448fa38231d4f46da0a330782" alt=""
- Set permissions for the configuration file
sudo chown prometheus:prometheus /etc/prometheus/prometheus.yml
- Create service file:
sudo nano /etc/systemd/system/prometheus.service
- Paste service content:
[Unit]Description=Monitoring system and time series databaseDocumentation=https://prometheus.io/docs/introduction/overview/ man:prometheus(1)After=time-sync.target
[Service]Restart=on-failureUser=prometheusEnvironmentFile=/etc/default/prometheusExecStart=/opt/prometheus/prometheus $ARGS --web.listen-address=:9099 --config.file=/etc/prometheus/prometheus.yml --storage.tsdb.path=/var/lib/prometheusExecReload=/bin/kill -HUP $MAINPIDTimeoutStopSec=20sSendSIGKILL=no
# systemd hardening-optionsAmbientCapabilities=CapabilityBoundingSet=DeviceAllow=/dev/null rwDevicePolicy=strictLimitMEMLOCK=0LimitNOFILE=8192LockPersonality=trueMemoryDenyWriteExecute=trueNoNewPrivileges=truePrivateDevices=truePrivateTmp=truePrivateUsers=trueProtectControlGroups=trueProtectHome=trueProtectKernelModules=trueProtectKernelTunables=trueProtectSystem=fullRemoveIPC=trueRestrictNamespaces=trueRestrictRealtime=trueSystemCallArchitectures=native
[Install]WantedBy=multi-user.target
data:image/s3,"s3://crabby-images/4c536/4c5369ae8cde6dcd5c0c51f275cbf54738f1bc43" alt=""
- Start Prometheus:
sudo systemctl daemon-reloadsudo systemctl enable prometheussudo systemctl start prometheussudo systemctl status prometheus
data:image/s3,"s3://crabby-images/86a58/86a588520f4a1d58e7880ae9e55e6697183f7915" alt=""
2. Installing Node Exporter
Node Exporter collects hardware and OS metrics.
- Download and install Node Exporter:
cd ~wget https://github.com/prometheus/node_exporter/releases/download/v1.5.0/node_exporter-1.5.0.linux-amd64.tar.gztar xvf node_exporter-1.5.0.linux-amd64.tar.gzsudo cp node_exporter-1.5.0.linux-amd64/node_exporter /usr/local/bin/
data:image/s3,"s3://crabby-images/31c70/31c709a63389ce6d2be18d973605b115af686b12" alt=""
- Create service file:
sudo nano /etc/systemd/system/node_exporter.service
- Insert service file content:
[Unit]Description=Node ExporterWants=network-online.targetAfter=network-online.target
[Service]User=rootExecStart=/root/node_exporter-1.5.0.linux-amd64/node_exporter --web.listen-address=:9200Restart=always
[Install]WantedBy=default.target
data:image/s3,"s3://crabby-images/83d59/83d5927050b771905fca3e915a0d56d9b0fe7bda" alt=""
(You can custom port if get conflict)
- Start Node Exporter:
chmod +x /root/node_exporter-1.5.0.linux-amd64/node_exportersystemctl daemon-reloadsudo systemctl enable node_exportersystemctl start node_exportersystemctl status node_exporter
data:image/s3,"s3://crabby-images/5a084/5a0840c492b97aa6c1b6422cb27110a517df13f2" alt=""
3. Installing Grafana
Grafana is an open-source platform for data analytics and visualization.
- Install Grafana:
sudo apt-get install -y software-properties-commonsudo add-apt-repository "deb https://packages.grafana.com/oss/deb stable main"wget -q -O - https://packages.grafana.com/gpg.key | sudo apt-key add -sudo apt-get updatesudo apt-get install grafanasudo systemctl enable grafana-server
data:image/s3,"s3://crabby-images/e7166/e71660f3780275c9db29b4fe54685868b0321a81" alt=""
data:image/s3,"s3://crabby-images/89a1c/89a1c01084508a5e6e997641b4c80f17f9a8bd5d" alt=""
- Start Grafana:
sudo systemctl start grafana-serversudo systemctl status grafana-server
data:image/s3,"s3://crabby-images/960e1/960e15097487d2d9809d670693f22995bf929e66" alt=""
4. Configuring Grafana Dashboard
- Access Grafana web interface:
Open your browser and navigate to
http://your_server_ip:3000
data:image/s3,"s3://crabby-images/026b5/026b5728fc4c12267dc9dc3a687b8a50a3416957" alt=""
-
Default login:
admin/admin
then change to your password -
Add Prometheus as a data source: Click
"Add new data source"
and select Prometheus
data:image/s3,"s3://crabby-images/eb05a/eb05a71b4073cd1f791924709f37a7788bd1b128" alt=""
Enter http://localhost:9099 as the Prometheus server URL. (This port the same port in Prometheus service config)
data:image/s3,"s3://crabby-images/b4864/b4864d521446cec76862ce3c341141b069269e51" alt=""
Click "Save & Test"
at the bottom
- Import Dashboard: Go to Dashboards and click “Upload JSON file”
data:image/s3,"s3://crabby-images/671fb/671fb5519d42a30acadc0c80330de5370ca9910c" alt=""
Upload the downloaded JSON file Select the Prometheus data source you just added
Download the Story-grafana-json-file from https://story.josephtran.co/story_validator.json
data:image/s3,"s3://crabby-images/8c47a/8c47a17622d387651cfbc1ed3f0768009610f92f" alt=""
- Customize Dashboard:
Adjust time ranges, add new panels, or modify existing ones as needed
data:image/s3,"s3://crabby-images/3accf/3accfadba24582b876268893b201e43c434bc4c1" alt=""
Preview: https://story-dashboard.josephtran.xyz/ | username: user
| password: 123456
5. Troubleshooting
- If Prometheus fails to start, check the configuration file for syntax errors
- Ensure all necessary ports are open in your firewall
- Check service logs using
journalctl -u [service_name]
for any error messages
6. Maintenance
- Regularly update Prometheus, Node Exporter, and Grafana to their latest versions
- Backup your Grafana dashboards and Prometheus data periodically
- Monitor disk usage of the Prometheus data directory
Setup Alert
data:image/s3,"s3://crabby-images/b6264/b6264e7c8443022386ecb52f7090d85c5f6fc897" alt=""
data:image/s3,"s3://crabby-images/102d5/102d591990444a4303813be00fde6f45a846ef09" alt=""
#Conclusion:
-
You now have a fully functional monitoring system for your node.
-
This setup allows you to visualize system metrics, set up alerts, and gain insights into your node’s performance.
-
Remember to regularly check and update your monitoring setup to ensure it remains effective and secure.
-
This comprehensive guide should provide a solid foundation for setting up Grafana to monitor your node.
-
It covers all the necessary steps from installation to configuration, and includes some basic troubleshooting and maintenance tips.