Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Support for unordered transactions for CosmosSDK-based chains #3763

Open
2 of 7 tasks
adizere opened this issue Jan 9, 2024 · 1 comment
Open
2 of 7 tasks

Support for unordered transactions for CosmosSDK-based chains #3763

adizere opened this issue Jan 9, 2024 · 1 comment
Labels
I: dependencies Internal: related to dependencies I: logic Internal: related to the relaying logic O: performance Objective: cause to improve performance O: reliability Objective: cause to improve trustworthiness and consistent performing
Milestone

Comments

@adizere
Copy link
Member

adizere commented Jan 9, 2024

Summary

For Cosmos SDK-based chains, the next version (i.e., likely SDK v0.51) will have support for executing unordered transactions.

This means the Hermes relayer will not need to include nonces anymore. Also, Hermes can not longer make ordering assumptions among transactions it is submitting (eg if nonce X has client update, it should be executed before nonce X+1 that depends on X).

On the positive side, if Hermes manages correctly the pipeline of submitted transactions, this feature should enable better UX by eliminating problems with "sequence mismatch".

The feature is unreleased as of today

https://github.com/cosmos/cosmos-sdk/blob/f431a5039cecd04c3d66f0c43b9df75b89d88037/CHANGELOG.md?plain=1#L43

Context

Acceptance Criteria

  • New design for dealing with unordered transactions in Hermes
  • Test scenarios

For Admin Use

  • Not duplicate issue
  • Appropriate labels applied
  • Appropriate milestone (priority) applied
  • Appropriate contributors tagged
  • Contributor assigned/self-assigned
@adizere adizere added I: logic Internal: related to the relaying logic I: dependencies Internal: related to dependencies O: performance Objective: cause to improve performance O: reliability Objective: cause to improve trustworthiness and consistent performing labels Jan 9, 2024
@github-project-automation github-project-automation bot moved this to 🩹 Triage in Hermes Jan 9, 2024
@romac romac added this to the v1.9 milestone Jan 9, 2024
@ancazamfir
Copy link
Collaborator

ancazamfir commented Jan 11, 2024

This means the Hermes relayer will not need to include nonces anymore. Also, Hermes can not longer make ordering assumptions

We will need to be very careful with any changes we make (if we do) when submitting transactions to SDK v0.51. And properly test.
For legacy hermes we serialize the transaction submission anyway (via the single chain runtime) so we cannot parallelize.

If we don't explicitly flag the Tx-es as unordered then the behavior should be the same as before (so we can still make the ordering assumption).

The only potential advantage would be to simulate as unordered so we don't run into nonce mismatch due to recheck (i.e. we get the got > expected error that we ignore today) and proceed with the Tx submission (we must not mark unordered here).
But then we may run into other simulation failures if IBC dependent transactions have not been rechecked and we will need to figure out what to do then (still ignore but we need to figure this out from other error types and not sure about the accuracy there).
Then we still want to catch the got < expected mismatch case that indicates multiple usage of same account from multiple instances (in this case we need to re-cache the account nonce).

So at first look it is not clear to me how to take advantage of the proposal and just hope the legacy way will still work fine.

@romac romac modified the milestones: v1.9, v1.10 Apr 2, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
I: dependencies Internal: related to dependencies I: logic Internal: related to the relaying logic O: performance Objective: cause to improve performance O: reliability Objective: cause to improve trustworthiness and consistent performing
Projects
Status: 🩹 Triage
Development

No branches or pull requests

3 participants