This code runs on an external server outside of the Hedera mirror node deployment, and periodically polls the REST APIs exposed by the Hedera mirror node to ensure that the deployed APIs are working. It also provides a simple dashboard to monitor the status.
A process runs that periodically polls the APIs exposed by the deployment of a Hedera mirror node. It then checks the responses using a few simple checks for those APIs. The results of these checks are exposed as a set of REST APIs by this monitoring service as follows:
API | HTTP return code | Description |
---|---|---|
/api/v1/status | 200 (OK) | Provides a list of results of all tests run on all servers |
/api/v1/status/{id} | 200 (OK) | If all tests pass for a server, then it returns the results |
4xx | If any tests fail for a server, or if the server is not running, then it returns a 4xx error code to make it easy to integrate with alerting systems |
A dashboard polls the above-mentioned APIs and displays the results.
- List of addresses of Hedera mirror nodes that you want to monitor
- An existing topic ID of the target Hedera Mirror node environment if you want to run topic message tests
- An external server where you want to run this code to monitor the mirror node. You will need two TCP ports on the server.
- npm
- PM2
git clone [email protected]:hashgraph/hedera-mirror-node.git
cd hedera-mirror-node/hedera-mirror-rest/monitoring
To install the dependencies and configure monitor_apis:
cd monitor_apis
npm install
vi config/serverlist.json // Insert the mirror node deployments you want to monitor
To customize per-resource configuration:
- set
enabled
totrue
orfalse
to enable / disable tests for a resource freshnessThreshold
(in seconds) forbalance
,transaction
,topic
, andtoken
(balances of a token) can be adjusted independently if needed. Set to 0 to disable freshness check for a resourceintervalMultiplier
for all resources. The tests for a resource will run everyinterval * intervalMultiplier
seconds. Forstateproof
, it defaults to 10, so the tests run at a lower frequency to reduce costlimit
threshold foraccount
,balance
,transaction
,topic
, andtoken
can be adjusted independently if needed, e.g.,for environments with lower traffic volume. Fortoken
,tokenBalancesLimit
is the limit for a token's balance query andtokensLimit
is the limit for the token discovery query- set
topic.topicId
to an existing topic ID of the target environment. If not set, topic message tests will be skipped - set
token.tokenId
to an existing token ID of the target environment in case it's needed to pass certain token tests, e.g.,tokenBalancesLimit
for the token. If not set, the tests will use the first token from the token discovery API response
See default.serverlist.json for a full list of configuration properties.
To run the monitor_apis backend:
PORT=3000 pm2 start server.js --node-args="--experimental-specifier-resolution=node"
The server will start polling Hedera mirror nodes specified in the config/serverlist.json file.
The default interval to populate the data is 60 seconds. You can verify the output
using curl http://<host>:<port>/api/v1/status
command.
To run the dashboard (from hedera-mirror-rest/monitoring
directory):
cd monitor_dashboard
echo '{"monitorAddress": "localhost:3000"}' > config.json
pm2 serve . 3001 // Serve the dashboard html pages on another port
Using your browser, connect to http://<host>:<port>/index.html
Create a custom serverlist.json
in the current working directory. Then execute:
docker run -it --rm -e CONFIG_PATH=/config -v "${PWD}/serverlist.json:/config/serverlist.json" -p 8080:8080 -p 3000:3000 gcr.io/mirrornode/hedera-mirror-rest-monitor