- 
    Type:Bug 
- 
    Resolution: Fixed
- 
    Priority:Blocker - P1 
- 
    Affects Version/s: None
- 
    Component/s: None
- 
        Storage - Ra 2022-02-07, Storage - Ra 2022-02-21, Storage - Ra 2022-03-07
- 
        8
Doing an operation that requires exclusive access to a handle (such as verify) closes existing references, which checkpoints it if the tree is dirty. But this only checkpoints that tree, not others that might need to be in sync with it (such as the history store, or trees that were recently also updated as part of a single transaction). Consequently the on-disk state at that point is not consistent and this creates a problem if the system crashes without taking another full checkpoint.
There's code that prohibits exclusive ops on dirty trees that have a stable timestamp (see WT-7750) but the problem also exists with non-timestamped tables. I'll attach a Python test that splits a transaction across two tables and then observes half of it after crashing. It's also possible to create a comparable situation where values needed by RTS are not in the history store because the history store wasn't checkpointed at the same time, but doing so is somewhat more involved.
This issue is similar to WT-4070 (which appears to be the same problem for timestamped tables) and it's clearly related to WT-4414 as well, except that WT-4414 was apparently fixed.
- causes
- 
                    WT-8883 Change to disallow single file checkpoint has MDB server fallout -         
- Closed
 
-         
- 
                    SERVER-64026 Update WT operations that require exclusive access to a dhandle -         
- Closed
 
-         
- depends on
- 
                    SERVER-63605 validate_tests fails after some WT changes -         
- Closed
 
-         
- 
                    WT-8771 Checkpoint cleanup to dirty obsolete page with overflow items -         
- Closed
 
-         
- is related to
- 
                    WT-4070 WiredTiger recovery can checkpoint data referencing pieces of a transaction -         
- Closed
 
-         
- 
                    WT-4414 Only flush dirty data during checkpoints if logging is disabled -         
- Closed
 
-         
- 
                    WT-7750 exclusive handle access fails if cache contains dirty data -         
- Closed
 
-         
- related to
- 
                    WT-8829 Use the new durability test -         
- Closed
 
-         
- 
                    WT-8813 Improve access to methods requiring an exclusive handle -         
- Backlog
 
-         
- 
                    WT-15810 Update code style to reflect current use of FIXME comments -         
- In Code Review
 
-         
- 
                     WT-8892
        Disallow single file checkpoint from MDB server WT-8892
        Disallow single file checkpoint from MDB server-         
- Closed
 
-