Skip to content

Latest commit

 

History

History
106 lines (70 loc) · 6.69 KB

raft-validators.md

File metadata and controls

106 lines (70 loc) · 6.69 KB

High-availability validator setup

:::danger This Request for Proposals is closed, meaning we are not looking for any more proposals on this topic at the moment. :::

  • Status: Closed
  • Proposer: mmagician
  • Projects you think this work could be useful for: Polkadot & Kusama Validators

Project Description 📄

Summary

Validator leader selection via Raft consensus. Inspired by internal discussions & certus.one active-active validator setup.

Present state

Currently, the recommended setup is to have one active node per validator. The main advantage of this approach is that it removes the danger of equivocation, thus preventing slashing. The key drawback is the lack of a ready backup machine to takeover the responsibility of producing blocks, voting on finality etc. in case the primary one fails.

The drawback can be somewhat remedied by having a backup node in sync, but without access to the session keys necessary for authoring blocks. The process of replacing the keys, however, is manual. Furthermore, the session keys cannot be replaced mid-session and this introduces a time delay for when the validator is active again.

Solution

Rather than relying on one validator node to perform the work, what if we had multiple nodes equally capable of signing messages, yet still avoiding the risk of equivocation? The proposed approach relies on recognising a distinction between signing a message and submitting it.

Since all our validator nodes are trusted and we don't worry about censorship resistance, we can leverage a leader-follower model to ensure high availibility. Raft is a good candidate - it offers a simple consensus mechanism, fault-tolerance and performance. It ensures only one leader is ever in charge of interacting with the blockchain, while the followers simply receive the state updates and automatically replace the leader in case of a failure.

Deliverables 🔩

  • Total Estimated Duration: 3 months
  • Full-time equivalent (FTE): 1
  • Total Costs: 30,000 DAI

Milestone 1 - Block production PoC

The main goal of the PoC is to add a switch to the substrate node which allows it to decide whether it's a valid block producer or not (i.e. to execute the BABE protocol). The concept could be analogous to the remote signing feature, in that the node could reach out to an endpoint (local or remote) which tells it whether the node is allowed to author new blocks.

The service should contain only basic logic (e.g. return true for node0 and return false for node1 & node2).

  • Estimated Duration: 1 month
  • FTE: 1
  • Costs: 10,000 DAI
Number Deliverable Specification
1. Basic service Create a microservice (to run locally or remotely) that accepts connections from the substrate node.
2. Microservice logic Hardcoded logic for deciding which node is the leader
3. Update substrate client Modify the substrate code to reach out to a remote service for receiving permission (or not) for submitting blocks
4. Allow as optional The choice of using an outside decision making agent for block submission should be configurable in the cli
5. Integration test A dockerised setup that allows to test the developed PoC

Milestone 2 - Voting & liveness PoC

Similar to the previous milestone, but concerning other validator jobs, namely voting on finalised blocks (GRANDPA) and communicating liveness (I'm online)

  • Estimated Duration: 2 weeks
  • FTE: 1
  • Costs: 5,000 DAI
Number Deliverable Specification
1. Update substrate client - finalisation Modify the substrate code to reach out to a remote service for receiving permission (or not) for submitting votes for finalised blocks (GRANDPA)
2. Update substrate client - I'm online Modify the substrate code to reach out to a remote service for receiving permission (or not) for submitting I'm online messages

Milestone 3 - Raft consensus

Replace the dummy microservice with a Raft consensus mechanism, responsible for leader selection.

Each node should integrate a Raft client in its code. A good candidate is tikv-client. It should be able to push/receive information on what the latest authored block is (persistent data storage) & act accordingly.

  • Estimated Duration: 1 month
  • FTE: 1
  • Costs: 10,000 DAI
Number Deliverable Specification
1. Run the necessary Raft services Add a key-value (or other) store binaries that follows a Raft consensus. They should run alongside the validator code
2. Integrate a Raft client into the node Extend the block submission logic to allow only Raft-selected leader as a valid block submitter
3. Integration test A dockerised setup that allows to test the Raft consensus mechanism

Milestone 4 - Production readiness

Take the previous developments to a state where it's ready to be deployed in production as part of a Polkadot/Kusama validator setup.

  • Estimated Duration: 2 weeks
  • FTE: 1
  • Costs: 5,000 DAI
Number Deliverable Specification
1. Security Make sure that a firewall and proper networking is in place
2. Monitoring Feed the Raft consensus data into Prometheus and display basic info in Grafana.
3. Validator setup integration Integrate the above into one of the validator-setup repositories (e.g. https://github.com/w3f/polkadot-secure-validator)

Future plans

At some point, BABE will be replaced with Sassafras (see 37 & 4600) which is likely going to affect the operation of the Raft consensus and thus should be addressed.

Furthermore, there are plans for developing additional mechanisms for validator slashing protection (see 7398). In particular:

  • the leader might need to perform an on-chain key registration upon being appointed.
  • followers never increment counters nor generate new tags (unless being promoted)

This high availability setup, when adapted, should still make conceptual sense, because its main purpose is ensuring redundance and quick replacement of the main node & as such will not interfere with the extended key registration proposed in the mentioned issue.