Skip to content

Latest commit

 

History

History
37 lines (24 loc) · 3.01 KB

validator-node-architecture.md

File metadata and controls

37 lines (24 loc) · 3.01 KB

Validator Node Architecture

The System architecture of a validator node on the Energy Web Chain is made up of two main components. (Note: the original node architecture featured a node control component, but it was never used and formally deprecated in 2020).

High-level Validator Node Architecture

Client: The OpenEthereum or Nethermind client that connects the validator to the Energy Web Chain, collects transactions and proposes blocks according to the AuRa consensus algorithm. Read the documentation of the OpenEthereum client here, and the Nethermind client here. \

Telemetry: There is a monitoring system on the validator node that uses Telegraf to securely send telemetry to an InfluxDB that is connected to Grafana and the EWC Validator Data Warehouse & Dashboard. The use of telemetry is opt-in. Validators can disable it if they have their own monitoring system in place that allows for real time tracking of all relevant metrics.

Telemetry data includes:

  • CPU usage of the host machine
  • Memory usage of the host machine
  • Disk usage of the host machine
  • Number of connected peers
  • List of visible P2P peers
  • Current block (latest block synced by the node)
  • Network latency to 3 different and major locations (e.g. cloudflare, google, amazon)
  • Network throughput
  • Network error rate
  • Number of SSH keys for the host machine
  • Service status for SSH, docker and the parity container
  • SHA256 hashes of key system components/binaries
  • Current chain specification file (or hash)

As this is sensitive data, we rely on well established industry solutions to transfer these metrics off the validator node. Telegraf is a server agent that plugs into many different services to collect data. Telegraf collects relevant metrics from the host machine and the custom-built parity metrics collector which allows Telegraf to receive the metrics from the parity client. For more information on Telegraf visit: https://docs.influxdata.com/telegraf/v1.10/

The collected metrics are then stored in an InfluxDB database and can be visualized using the monitoring tool Grafana. For more information on influxDB visit: https://docs.influxdata.com/influxdb/v1.7/

For more information on Grafana visit: https://grafana.com/docs/

The use of telemetry is opt-in. Validators can disable it if they have their own monitoring system in place that allows for real time tracking of all relevant metrics.\

All components are run in separate docker containers managed by docker compose. For additional information on docker visit: https://docs.docker.com/ and https://docs.docker.com/compose/