This shows you the differences between two versions of the page.
Next revision | Previous revision | ||
how_qortal_s_consensus_works [05/25/2021 16:15] – created gfactor | how_qortal_s_consensus_works [11/02/2023 14:12] (current) – crowetic | ||
---|---|---|---|
Line 1: | Line 1: | ||
- | Here is an explanation from @CalDescent (Qortal’s | + | ====== How Qortal’s |
- | Every node with at least 1 minting account attached is eligible to sign the next block. The timestamp of each block must be between 30 seconds and 90 seconds after the block that precedes it. However, the actual timestamp of the minted block will depend on the minter, based on two main factors: | + | {{: |
- | 1. Key distance. This is essentially | + | Every node with a Level 5 (or higher) self-share "minting |
- | 2. Minter level. The number from Step 1 is then divided by the account | + | 1. **Key distance.** This is essentially a lottery for each block, where each minting |
- | Lower numbers translate to a lower time delta for the next block, and higher numbers translate to higher time deltas. So some nodes could sign their blocks with a timestamp 50 seconds after the previous block, and others could sign blocks with timestamp 80 seconds after the previous block, etc etc. In practice, timestamps range from around 60-90 seconds because of the way they are weighted, with the average | + | 2. **Minter level.** The number from Step 1 is then divided by the account level of the block signer. So a level 5 account would end up with a number 5 times lower than a level 1 account, assuming that they both had comparable key distances. However, if a level 1 produces a key distance 10 times smaller than a level 5, its resulting number would be smaller than the level 5's number. On average, higher levels will produce smaller numbers than lower levels. |
+ | |||
+ | Lower numbers translate to a lower time delta for the next block, and higher numbers translate to higher time deltas. So some nodes could sign their blocks with a timestamp 50 seconds after the previous block, and others could sign blocks with timestamp 80 seconds after the previous block, etc etc. In practice, timestamps range from around 60-90 seconds because of the way they are weighted, with the average historical delta being around 65 seconds. | ||
Each block has a " | Each block has a " | ||
Line 15: | Line 17: | ||
Nodes sync to the most ideal block that they can find, and the process repeats. If another, better block is found by a subset of the network, this will eventually propagate through and cause nodes on a different block to " | Nodes sync to the most ideal block that they can find, and the process repeats. If another, better block is found by a subset of the network, this will eventually propagate through and cause nodes on a different block to " | ||
- | To summarize with this system: | ||
- | |||
- | 1) Higher level accounts are preferred as block signers, on average. | ||
- | 2) Verifiable randomness is created, to ensure that minters on each level get a reasonably equal distribution of blocks signed, and no-one can jump the queue by minting a block with an earlier timestamp than it should have. | ||
- | ---------- |