-
Notifications
You must be signed in to change notification settings - Fork 287
Profiling
This tutorial will help you set up monitoring for your Opera node so you can better understand its performance and identify potential problems.
- You should already be running an instance of Opera.
- Most of the steps and examples are for linux environment, basic terminal knowledge will be helpful
An Opera client collects lots of data which can be read in the form of a chronological database. To make monitoring easier, you can feed this into data visualisation software. There are multiple options available:
- Prometheus (pull model)
- InfluxDB (push model)
- Telegraf
- Grafana
- Datadog
- Chronograf
In this tutorial, we'll set up your Opera client to push data to InfluxDB to create a database and Grafana to create a graph visualisation of the data. Doing it manually will help you understand the process better, alter it, and deploy in different environments.
First, let's download and install InfluxDB. Various download options can be found at Influxdata release page. Pick the one that suits your environment. You can also install it from a repository. For example in Debian 10.4 based distribution:
$ sudo apt update -y && sudo apt upgrade -y
$ sudo apt install curl
$ curl -s https://repos.influxdata.com/influxdb.key | sudo apt-key add -
$ source /etc/os-release
$ echo "deb https://repos.influxdata.com/debian $(lsb_release -cs) stable" | sudo tee /etc/apt/sources.list.d/influxdb.list
$ sudo apt-get install influxdb -y
$ sudo systemctl unmask influxdb.service
$ sudo systemctl enable influxdb
$ sudo systemctl start influxdb
$ sudo apt install influxdb-client
After successfully installing InfluxDB, make sure it's running on background. By default, it is reachable at localhost:8086
. Before using influx client, you have to create new user with admin privileges. This user will serve for high level management, creating databases and users.
curl -XPOST "http://localhost:8086/query" --data-urlencode "q=CREATE USER fantom WITH PASSWORD 'fantom' WITH ALL PRIVILEGES"
Now you can use influx client to enter InfluxDB shell with this user.
$ influx -username 'fantom' -password 'fantom'
Directly communicating with InfluxDB in its shell, you can create database and user for opera metrics.
create database opera
Verify created entries with:
show databases
show users
You cam leave InfluxDB shell by input exit
into the command.
InfluxDB is running and configured to store metrics from Opera.
After setting up database, we need to enable metrics collection in Opera. Pay attention to METRICS AND STATS OPTIONS in opera --help
. Multiple options can be found there, in this case we want Opera to push data into InfluxDB. Basic setup specifies endpoint where InfluxDB is reachable and authentication for the database.
nohup ./build/opera --genesis mainnet.g --metrics --metrics.influxdb --metrics.influxdb.database "opera" --metrics.influxdb.username "fantom" --metrics.influxdb.password "fantom" &
You can verify that Opera is successfully pushing data, for instance by listing metrics in database. In InfluxDB shell:
use opera
show measurements
Next step is installing Grafana which will interpret data graphically. Follow installation process for your environment in Grafana documentation. Make sure to install OSS version if you don't want otherwise. Example installation steps for Debian 10.4 distributions using repository:
$ curl -tlsv1.3 --proto =https -sL https://packages.grafana.com/gpg.key | sudo apt-key add -
$ echo "deb https://packages.grafana.com/oss/deb stable main" | sudo tee -a /etc/apt/sources.list.d/grafana.list
$ sudo apt update
$ sudo apt install grafana
$ sudo systemctl enable grafana-server
$ sudo systemctl start grafana-server
When you've got Grafana running, it should be reachable at localhost:3000
. Use your preferred browser to access this path, then login with the default credentials (user: admin and password: admin). When prompted, change the default password and save.
You will be redirected to the Grafana home page. First, set up your source data. Click on the configuration icon in the left bar and select "Data sources".
If there aren't any data sources created yet, click on [Add data source] to define one.
For this setup, select "InfluxDB" and proceed.
Data source configuration is pretty straight forward if you are running tools on the same machine. You need to set the InfluxDB address and details for accessing the database. Refer to the picture below.
If everything is complete and InfluxDB is reachable, click on [Save and test] and wait for the confirmation to pop up.
Grafana is now set up to read data from InfluxDB. Now you need to create a dashboard which will interpret and display it. Dashboards properties are encoded in JSON files which can be created by anybody and easily imported. On the left bar, click on [Import].
For a Opera monitoring dashboard, you can download the built-in JSON template and upload it in the "Import page" in Grafana. After saving the dashboard, it should look like this:
We can modify your dashboards. Each panel can be edited, moved, removed or added. You can change your configurations. It's up to you! To learn more about how dashboards work, refer to Grafana's documentation. You might also be interested in Alerting. This lets you set up alert notifications for when metrics reach certain values. Various communication channels are supported.