You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

54 lines
3.5 KiB

  1. # BFT time in Tendermint
  2. Tendermint provides a deterministic, Byzantine fault-tolerant, source of time.
  3. Time in Tendermint is defined with the Time field of the block header.
  4. It satisfies the following properties:
  5. - Time Monotonicity: Time is monotonically increasing, i.e., given
  6. a header H1 for height h1 and a header H2 for height `h2 = h1 + 1`, `H1.Time < H2.Time`.
  7. - Time Validity: Given a set of Commit votes that forms the `block.LastCommit` field, a range of
  8. valid values for the Time field of the block header is defined only by
  9. Precommit messages (from the LastCommit field) sent by correct processes, i.e.,
  10. a faulty process cannot arbitrarily increase the Time value.
  11. In the context of Tendermint, time is of type int64 and denotes UNIX time in milliseconds, i.e.,
  12. corresponds to the number of milliseconds since January 1, 1970. Before defining rules that need to be enforced by the
  13. Tendermint consensus protocol, so the properties above holds, we introduce the following definition:
  14. - median of a Commit is equal to the median of `Vote.Time` fields of the `Vote` messages,
  15. where the value of `Vote.Time` is counted number of times proportional to the process voting power. As in Tendermint
  16. the voting power is not uniform (one process one vote), a vote message is actually an aggregator of the same votes whose
  17. number is equal to the voting power of the process that has casted the corresponding votes message.
  18. Let's consider the following example:
  19. - we have four processes p1, p2, p3 and p4, with the following voting power distribution (p1, 23), (p2, 27), (p3, 10)
  20. and (p4, 10). The total voting power is 70 (`N = 3f+1`, where `N` is the total voting power, and `f` is the maximum voting
  21. power of the faulty processes), so we assume that the faulty processes have at most 23 of voting power.
  22. Furthermore, we have the following vote messages in some LastCommit field (we ignore all fields except Time field):
  23. - (p1, 100), (p2, 98), (p3, 1000), (p4, 500). We assume that p3 and p4 are faulty processes. Let's assume that the
  24. `block.LastCommit` message contains votes of processes p2, p3 and p4. Median is then chosen the following way:
  25. the value 98 is counted 27 times, the value 1000 is counted 10 times and the value 500 is counted also 10 times.
  26. So the median value will be the value 98. No matter what set of messages with at least `2f+1` voting power we
  27. choose, the median value will always be between the values sent by correct processes.
  28. We ensure Time Monotonicity and Time Validity properties by the following rules:
  29. - let rs denotes `RoundState` (consensus internal state) of some process. Then
  30. `rs.ProposalBlock.Header.Time == median(rs.LastCommit) &&
  31. rs.Proposal.Timestamp == rs.ProposalBlock.Header.Time`.
  32. - Furthermore, when creating the `vote` message, the following rules for determining `vote.Time` field should hold:
  33. - if `rs.LockedBlock` is defined then
  34. `vote.Time = max(rs.LockedBlock.Timestamp + config.BlockTimeIota, time.Now())`, where `time.Now()`
  35. denotes local Unix time in milliseconds, and `config.BlockTimeIota` is a configuration parameter that corresponds
  36. to the minimum timestamp increment of the next block.
  37. - else if `rs.Proposal` is defined then
  38. `vote.Time = max(rs.Proposal.Timestamp + config.BlockTimeIota, time.Now())`,
  39. - otherwise, `vote.Time = time.Now())`. In this case vote is for `nil` so it is not taken into account for
  40. the timestamp of the next block.