Semantics of min_ledger_time

Yes, that’s correct. When setting the min_ledger_time_rel you’re basically making a statement that the transaction will probably take a long time to compute upfront, and you want to give the participant enough time to finish the computation and send it to the ledger. You can set min_ledger_time_rel fairly generously, because the participant delays sending the transaction until ledger_effective_time - avg_transaction_latency.

An improvement to that (in terms of size of the time window) would be to send the transaction to the ledger at ledger_effective_time - min_skew.

Almost. With min_ledger_time_rel you give the participant more time to do the initial command interpretation. So setting min_ledger_time_rel to a value that is greater than the time it takes to interpret the command will always be beneficial (modulo contention on contracts/contract keys). If a transaction takes 10 seconds to validate but the skew window is only 5 seconds, even if you set min_ledger_time_rel to 15 seconds so that the command interpretation goes through successfully, it will actually not be processed within the permitted time window on the committer side.

In summary:

  1. There is no need to “guess” the absolute ledger time for a command submission, you can safely use min_ledger_time_rel for that.
  2. Transactions that take a long time to process and a small skew window just doesn’t work. The only chance you have for getting the transaction committed is to increase the skew window via the Config Admin Service if you happen to be an admin on the ledger.
5 Likes