4.8 KiB
description: Frequently asked questions FAQ and answers for troubleshooting Pantheon use
Monitoring Pantheon
Monitor Node Performance and Connectivity Using the JSON-RPC API
You can monitor node performance using the debug_metrics
JSON-RPC API method.
Monitor Node Performance Using Prometheus
Use the --metrics-enabled option to enable the Prometheus monitoring and
alerting service to access Pantheon metrics. You can also visualize the collected data using Grafana.
A sample Pantheon Grafana dashboard is provided.
To specify the host and port on which Prometheus accesses Pantheon, use the --metrics-host and
--metrics-port options.
The default host and port are 127.0.0.1 and 9545.
You can install other Prometheus components such as the Alert Manager. Additional configuration is not required for these components because Prometheus handles and analyzes data directly from the feed.
To use Prometheus with Pantheon, install the prometheus main component. On MacOS, install with Homebrew:
brew install prometheus
Setting up and Running Prometheus with Pantheon
To configure Prometheus and run with Pantheon:
-
Configure Prometheus to poll Pantheon. For example, add the following yaml fragment to the
scrape_configsblock of theprometheus.ymlfile:job_name: pantheon-dev scrape_interval: 15s scrape_timeout: 10s metrics_path: /metrics scheme: http static_configs: - targets: - localhost:9545 -
Start Pantheon with the
--metrics-enabledoption. To start a single node for testing with metrics enabled:pantheon --network=dev --miner-enabled --miner-coinbase fe3b557e8fb62b89f4916b721be55ceb828dbd73 --rpc-http-cors-origins="all" --rpc-http-enabled --metrics-enabled -
In another terminal, run Prometheus specifying the
prometheus.ymlfile:prometheus --config.file=config.yml -
Open a web browser to
http://localhost:9090to view the Prometheus graphical interface. -
Choose Graph from the menu bar and click the Console tab below.
-
From the Insert metric at cursor drop-down, select a metric such as
pantheon_blockchain_difficulty_totalorpantheon_blockchain_heightand click Execute. The values are displayed below.Click the Graph tab to view the data as a time-based graph. The query string is displayed below the graph. For example:
{pantheon_blockchain_height{instance="localhost:9545",job="prometheus"}
Running Prometheus with Pantheon in Push Mode
The --metrics-enabled option enables Prometheus polling
Pantheon but sometimes metrics are hard to poll (for example, when running inside Docker containers with varying IP addresses).
The --metrics-push-enabled option enables Pantheon
to push metrics to a Prometheus Pushgateway.
To configure Prometheus and run with Pantheon pushing to a push gateway:
-
Configure Prometheus to read from a push gateway. For example, add the following yaml fragment to the
scrape_configsblock of theprometheus.ymlfile:```yml tab="Example" - job_name: push-gateway metrics_path: /metrics scheme: http static_configs: - targets: - localhost:9091 ``` -
Start the push gateway. The push gateway can be deployed using the Docker image:
docker pull prom/pushgateway docker run -d -p 9091:9091 prom/pushgateway -
Start Pantheon specifying the
--metrics-push-enabledoption and port of the push gateway:pantheon --network=dev --miner-enabled --miner-coinbase fe3b557e8fb62b89f4916b721be55ceb828dbd73 --rpc-http-cors-origins="all" --rpc-http-enabled --metrics-push-enabled --metrics-push-port=9091 --metrics-push-host=127.0.0.1 -
In another terminal, run Prometheus specifying the
prometheus.ymlfile:prometheus --config.file=config.yml -
View the Prometheus graphical interface as described in Setting up and Running Prometheus with Pantheon.