Ledger close times example: edits per reviews

This commit is contained in:
mDuo13
2021-11-29 14:23:57 -08:00
parent 77789f670f
commit f3aca0ccea
2 changed files with 15 additions and 12 deletions

View File

@@ -58,26 +58,29 @@ Generally speaking, the ledger cannot make any time-based measurements that are
### Example ### Example
Lets say the last close time is 12:00:00: The following examples demonstrate the rounding behavior of ledger close times, from the perspective of an example validator, following a ledger with the close time **12:00:00**:
**Current consensus round** **Current consensus round**
- A validator individually determines that the next close time should be 12:00:03 1. A validator notes that it was **12:00:03** when the ledger closed and entered consensus. The validator includes this close time in its proposals.
- This is then rounded down based on the close time resolution to 12:00:00 2. The validator observes that most other validators (on its UNL) proposed a close time of 12:00:02, and one other proposed a close time of 12:00:03. It changes its proposed close time to match the consensus of **12:00:02**.
- But since this is not greater than the last close time, it's incremented to 12:00:01 3. The validator rounds this value to the nearest close time interval, resulting in **12:00:00**.
- The validators then negotiate and agree that the next close time is 12:00:01 4. Since 12:00:00 is not greater than the previous ledger's close time, the validator adjusts the close time to be exactly 1 second after the previous ledger's close time. The result is an adjusted close time of **12:00:01**.
5. The validator builds the ledger with these details, calculates the resulting hash, and confirms in the [validation step](consensus.html#validation) that others did the same.
Non-validating servers do all the same steps, except they don't propose their recorded close times to the rest of the network.
**Next consensus round** **Next consensus round**
- In the next round validators project that the next close time should be 12:00:04 1. The next ledger enters consensus at **12:00:04** according to most validators.
- This is rounded down based on the close time resolution to 12:00:00 2. This rounds down again, to a close time of **12:00:00**.
- But again this is not greater than the last close time, so it's incremented to 12:00:02 3. Since this is not greater than the previous ledger's close time of 12:00:01, the adjusted close time is **12:00:02**.
**Next consensus round after that** **Next consensus round after that**
- Next validators determine that the next close time should be 12:00:05 1. The ledger after that enters consensus at **12:00:05** according to most validators.
- Which is rounded up based on the close time resolution to 12:00:10 2. This rounds up, based on the close time resolution, to **12:00:10**.
- Since this is greater than the last close time, that value is used 3. Since this value is larger than the previous ledger's close time, it does not need to be adjusted. **12:00:10** becomes the official close time.
## See Also ## See Also

View File

@@ -136,7 +136,7 @@ targets:
# Fix links from untranslated health-check.html: # Fix links from untranslated health-check.html:
"rippled-server-modes.html#stand-alone-mode": "rippled-server-modes.html#rippledサーバーをスタンドアロンモードで実行する理由" "rippled-server-modes.html#stand-alone-mode": "rippled-server-modes.html#rippledサーバーをスタンドアロンモードで実行する理由"
"server-doesnt-sync.html#normal-syncing-behavior": "server-doesnt-sync.html#通常の同期動作" "server-doesnt-sync.html#normal-syncing-behavior": "server-doesnt-sync.html#通常の同期動作"
# Fix link from untranslated negativeunl.html: # Fix link from untranslated negativeunl.html and ledgers.html:
"consensus.html#validation": "consensus.html#検証" "consensus.html#validation": "consensus.html#検証"
# Fix link from untranslated tickets.html: # Fix link from untranslated tickets.html:
"consensus.html#calculate-and-share-validations": "consensus.html#検証の計算と共有" "consensus.html#calculate-and-share-validations": "consensus.html#検証の計算と共有"