Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
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
Add feature to TXM to detect and purge stuck transactions #12881
Add feature to TXM to detect and purge stuck transactions #12881
Changes from 1 commit
246b04d
d47d88f
8c713dc
05c5a11
360d9fa
0a04fff
d26473c
1541c5a
1d4113d
c71ac14
2e46dde
8185dc8
20bfb9d
82e3a5d
db5264e
0d5b318
25105a1
491f9e3
338ab26
dc17b98
468b73b
736eb89
b2902c6
6eb5dc5
a5663ee
0cea37b
a3cd9b7
02306fe
a13605b
c2deae5
a5ea4aa
1cfb5cc
335033a
a5ba3a0
7513d36
4b41b4b
cc5764d
b1faa07
d67d79b
c4062f5
54b9c7c
d244012
0915400
c95d261
db5e5d9
31d69ba
90ec4a3
d81da52
a33460b
c08504b
88826a7
e400a36
File filter
Filter by extension
Conversations
Jump to
There are no files selected for viewing
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@poopoothegorilla FYI, this will need to be implemented in the in-memory store as well.
Hopefully there, it will be easier to fetch by state.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
👍 thanks for the ping will update when this gets merged in :)
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Tried to keep it as general as possible with in-memory in mind. But if there's any issue with it's compatibility with your work, let me know and I can adjust it and the logic accordingly to help.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
dont worry this is higher priority
Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I don't quite understand why you need to do all this.
At startup time, just let the map be empty.
If map value for a certain address is empty, means you can purge txs on this address immediately.
When you purge a Tx, then you set the map value.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I originally had it that way but was worried that we'd lose expected rate limiting on restart. If we restart right after a tx got purged, we'd immediately purge the next if one was stuck behind the original. If tx get cleared or reaped, there isn't much more we can do but thought I'd at least give best effort.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
rename this to:
findUnconfirmedTxWithLowestNonce()
Because this logic has nothing to do with stuck txs.
Also, for this struct, don't export any methods that are used internally only.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I was exporting this one primarily for testing