- 
    Type:Improvement 
- 
    Resolution: Fixed
- 
    Priority:Major - P3 
- 
    Affects Version/s: None
- 
    Component/s: None
- 
        None
- 
        8
- 
        v6.0, v5.0
WT-8290 introduced an API to determine whether an uncommitted transaction has been rolled back due to excessive pinned dirty cache pressure. This has been useful for load shedding purposes.
However, there remains a scenario where a single storage transaction that is individually too large to fit in cache is rolled back. One such transaction is going to be rolled back even if it runs in isolation. The rollback reason introduced in WT-8290 would just indicate that the transaction had to be aborted due to cache pressure, which would imply that it may succeed if retried later, while in reality this transaction is not going to ever succeed because it just doesn't fit in memory. This scenario is exemplified in SERVER-61909, where a single document insert with a large number of secondary index entries is rolled back and retried indefinitely.
It would be useful to distinguish between rolled back transactions that may be retried, and rolled back transactions that should not be retried and should just return an error to the client.
We should consider adding the ability to limit the maximum amount of dirty data generated by a transaction, and to roll it back with a specific reason if the limit is exceeded.
- depends on
- 
                    SERVER-68853 Remove invariant that a session stat needs to be a slow op stat -         
- Closed
 
-         
- is depended on by
- 
                    SERVER-61909 Hang inserting or deleting document with large number of index entries -         
- Closed
 
-         
- 
                    SERVER-64982 Extended lack of availability caused by transactions -         
- Closed
 
-         
- 
                    WT-9879 Fix overcounting of session txn dirty bytes statistic -         
- Closed
 
-         
- 
                    WT-10027 Session txn dirty statistic is incorrect -         
- Closed
 
-         
- related to
- 
                    WT-8707 Mongod reader yielding with WT::commit_transaction instead of rollback pins WT pages such that pages cannot be split/evicted by writer threads -         
- Closed
 
-         
- 
                    WT-8767 Return rollback instead of cache full after cache_max_wait timer expires -         
- Closed
 
-