- 
    Type:Improvement 
- 
    Resolution: Unresolved
- 
    Priority:Major - P3 
- 
    None
- 
    Affects Version/s: None
- 
    Component/s: Compaction
- 
        Storage Engines, Storage Engines - Persistence
- 
        StorEng - Defined Pipeline
- 
        5
Compaction periodically checks if the cache is stuck:
        /*
         * Periodically check if compaction has been interrupted or if eviction is stuck, quit if
         * this is the case.
         */
        if (first || ++i > 100) {
...
            if (__wt_cache_stuck(session))
                WT_ERR(EBUSY);
...
        }
Waiting for the cache to be stuck might be too late and put the system in trouble. Instead, we could have a conservative approach and use thresholds to know if the system is slowly becoming unstable. This was done for the background compaction thread in WT-13080.
One suggestion is to check periodically the right thresholds and if we are experiencing pressure for some time, it might be better to give up on compaction to avoid adding more pressure to the system.
- is related to
- 
                    WT-13080 Pause background compaction if we are under cache pressure -         
- Closed
 
-