Merged
Conversation
When we have broken transaction data in the database (such as from mongo getting OOM killed), it can cause cascade failure, where that document ends up getting too many transactions queued up against it. This can also happen if you have nothing but assert-only transactions against a single document. If we have lots of transactions, it becomes harder and harder to add new entries and clearing out a large queue is O(N^2) which means capping it is worthwhile. (It also makes the document grow until it hits max-doc-size.) The upper bound is still quite large, so it should not be triggered if everything is operating normally.
Still defaults to 1000 without any other configuration, but allows callers to know that they can be stricter/less strict.
…fix/jameinel-max-txn-queue-length
szank
approved these changes
Jul 5, 2017
Merged
libi
pushed a commit
to libi/mgo
that referenced
this pull request
Dec 1, 2022
…txn-queue-length Bound TXN queue lengths
bozaro
added a commit
to bozaro/mgo
that referenced
this pull request
Jul 3, 2025
Fix busy socket reuse and kill iterator from another connection
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
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.
See go-mgo#463.
Provides an opt-in failsafe upper bound to the length of the transaction queue. More thanks to @jameinel again for the hard work.