Uploaded image for project: 'Core Server'
  1. Core Server
  2. SERVER-102445

Improve SessionCatalog API to handle "kill oldest"

    • Type: Icon: Improvement Improvement
    • Resolution: Unresolved
    • Priority: Icon: Minor - P4 Minor - P4
    • None
    • Affects Version/s: None
    • Component/s: None
    • Replication
    • FarewellDaniel - 2025-02-18, HappyAddy - 2025-03-04
    • None
    • None
    • None
    • None
    • None
    • None
    • None

      In https://github.com/10gen/mongo/pull/33226 we needed the functionality "kill the oldest session" but piecing this together from the existing API was suboptimal, because of the way that class manages its locks through the API.

      Some options to improve it:

      • Add a "reduce" kind of API, SessionCatalog only provides "forEach" kind of functionality, but we don't know what the oldest is until after we've scanned them all, and we had to yield locks in between figuring the oldest and killing it.
      • make kill return optional (or StatusWith) rather than except. This at least makes it clear to callers that the session you ask for might not be there any more.
      • Facilitate manual locking (the "WithLock" pattern), tbh i don't like exposing locks over APIs given the above two options...

            Assignee:
            Unassigned Unassigned
            Reporter:
            nic.hollingum@mongodb.com Nic Hollingum
            Votes:
            0 Vote for this issue
            Watchers:
            6 Start watching this issue

              Created:
              Updated:
              None
              None
              None
              None