This page outlines a number of the key concepts behind the various technologies that Obol is developing.
A distributed validator is an Ethereum proof-of-stake validator that runs on more than one node/machine. This functionality is possible with the use of Distributed Validator Technology (DVT).
Distributed validator technology removes some of the single points of failure in validation. Should <33% of the participating nodes in a DV cluster go offline, the remaining active nodes can still come to consensus on what to sign and can produce valid signatures for their staking duties. This is known as Active/Active redundancy, a common pattern for minimizing downtime in mission critical systems.
Distributed Validator Node
A distributed validator node is the set of clients an operator needs to configure and run to fulfil the duties of a Distributed Validator Operator. An operator may also run redundant execution and consensus clients, an execution payload relayer like mev-boost, or other monitoring or telemetry services on the same hardware to ensure optimal performance.
In the above example, the stack includes Geth, Lighthouse, Charon and Teku.
An execution client (formerly known as an Eth1 client) specializes in running the EVM and managing the transaction pool for the Ethereum network. These clients provide execution payloads to consensus clients for inclusion into blocks.
Examples of execution clients include:
A consensus client's duty is to run the proof of stake consensus layer of Ethereum, often referred to as the beacon chain.
Examples of Consensus clients include:
Distributed Validator Client
A distributed validator client intercepts the validator client ↔ consensus client communication flow over the standardised REST API, and focuses on two core duties.
- Coming to consensus on a candidate duty for all validators to sign
- Combining signatures from all validators into a distributed validator signature
The only example of a distributed validator client built with a non-custodial middleware architecture to date is charon.
A validator client is a piece of code that operates one or more Ethereum validators.
Examples of validator clients include:
Distributed Validator Cluster
A distributed validator cluster is a collection of distributed validator nodes connected together to service a set of distributed validators generated during a DVK ceremony.
Distributed Validator Key
A distributed validator key is a group of BLS private keys, that together operate as a threshold key for participating in proof of stake consensus.
Distributed Validator Key Share
One piece of the distributed validator private key.
Distributed Validator Threshold
The number of nodes in a cluster that needs to be online and honest for their distributed validators to be online is outlined in the following table.
|Minimum to tolerate two offline nodes
|Minimum to tolerate two malicious nodes
|Minimum to tolerate three offline nodes
|Minimum to tolerate three malicious nodes
Distributed Validator Key Generation Ceremony
To achieve fault tolerance in a distributed validator, the individual private key shares need to be generated together. Rather than have a trusted dealer produce a private key, split it and distribute it, the preferred approach is to never construct the full private key at any point, by having each operator in the distributed validator cluster participate in what is known as a Distributed Key Generation ceremony.
A distributed validator key generation ceremony is a type of DKG ceremony. A ceremony produces signed validator deposit and exit data, along with all of the validator key shares and their associated metadata. Read more about these ceremonies here.