- 
    Type:Improvement 
- 
    Resolution: Fixed
- 
    Priority:Major - P3 
- 
    Affects Version/s: None
- 
    Component/s: None
- 
    None
- 
        Catalog and Routing
- 
        Fully Compatible
- 
        CAR Team 2025-02-17, CAR Team 2025-03-03, CAR Team 2025-03-17
- 
        2
- 
        None
- 
        None
- 
        None
- 
        None
- 
        None
- 
        None
- 
        None
Historically we needed to hold a collection/DB lock in order to access some sharding state, but since the introduction of the CSS/DSS these are effectively the locks we use to coordinate accessing that state. We don't need to hold a higher level lock anymore, so it doesn't make sense to enforce that through the API.
Some examples where we take those locks unnecessarily:
https://github.com/10gen/mongo/blob/dface7ce0b386b3917010b98aa35a09dbe414589/src/mongo/db/s/migration_source_manager.cpp#L411-L416
https://github.com/10gen/mongo/blob/dface7ce0b386b3917010b98aa35a09dbe414589/src/mongo/db/s/migration_source_manager.cpp#L634
https://github.com/10gen/mongo/blob/dface7ce0b386b3917010b98aa35a09dbe414589/src/mongo/db/s/migration_source_manager.cpp#L236
- fixes
- 
                    SERVER-58222 Investigate op_observer_sharding_impl.cpp lock acquisition -         
- Closed
 
-         
- 
                    SERVER-99704 Investigate if we can remove a lock ordering conflict in RangeDeleterServiceOpObserver -         
- Closed
 
-         
- is related to
- 
                    SERVER-101759 Investigate removing AutoGetCollections when calling filteringMetadata methods on the CSR -         
- Backlog
 
-         
- 
                    SERVER-101760 Investigate removing AutoGetCollections when calling index methods on the CSR -         
- Backlog
 
-         
- 
                    SERVER-101762 Investigate removing AutoGetDBs when calling set/clearDBInfo() on the DSS -         
- Backlog
 
-         
- 
                    SERVER-102535 Investigate removing AutoGetDBs when calling is/set/unsetMovePrimaryInProgress on the DSS -         
- Backlog
 
-         
- 
                    SERVER-101761 Investigate removing DB/Coll locks in shard_filtering_metadata_refresh.cpp -         
- Closed
 
-         
- 
                    SERVER-101785 Lock the database in Intent Exclusive mode (IX) instead of Exclusive mode (X) when setting or clearing database metadata in the authoritative model -         
- Closed
 
-