Network Architecture
Node Types and Roles
An Autonomys Network Node can run in several modes depending on configuration:
Full Node
Full Nodes participate fully in the network by processing all blocks and serving peers. Full nodes retain recent history and state for a configurable number of recent blocks until it is archived and pruned. A full node is a default configuration for farmers and operators.
Archival Node
Archival Nodes' responsibilities are a superset of those of full nodes. They retain the entire blockchain history and state and perform all the functions of full nodes. Archival nodes are helpful for block explorers and historical queries. The Subspace Foundation will maintain several archival nodes as a public good.
Light Client
A Light Client node does not retain the full blockchain state. Instead, it connects to full nodes and processes block headers but doesn't run the state transitions nor retain any history. Light clients are useful for mobile or low-resource devices that need to interact with the network without running a full node. For instance, it can run in a browser with Substrate Connect.
The network's health, robustness, and resistance to censorship rely on the constant online presence of numerous full nodes independently managed and spread across different geographic locations. Each full node supports newly joined nodes by providing them with the necessary block data to start their participation. Additionally, operating a full node allows the participant to verify all blocks, ensuring an authoritative assessment independently. Autonomys Network is dedicated to promoting decentralization through full nodes by keeping the hardware requirements low enough that individuals can run them from home while providing sufficient resources to support the network.
Node Roles
The Autonomys Network is made up of different types of nodes that each play a specific role:
Farmer
A Farmer is responsible for maintaining consensus (safety of the Consensus Chain). A Farmer plots pieces of Archival History to disk, farms the created plot for block rewards, and joins the DSN as a node for data retrieval (for syncing nodes, other farmers and returning data to various Clients).
Domain Operator
A Domain Operator is responsible for running arbitrary computations on Domains, state transitions, and maintaining state (liveness of the Execution Chain).
Timekeeper
A Timekeeper is responsible for running the Proof-of-Time chain and maintaining the randomness beacon for the Consensus Chain.
Last updated