Fix concurrent requests on same session hanging indefinitely #319
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
Concurrent tool calls with the same
mcp-session-idhung indefinitely due to race conditions in the MCP SDK'sStreamableHTTPServerTransportinternal state maps.Changes
_streamMapping,_requestToStreamMapping, and_requestResponseMapImplementation
Added queue infrastructure in
startStreamableHTTPServer():The queue processor ensures sequential execution:
Test Coverage
Added
test/concurrent-requests-test.tscovering:Original prompt
This section details on the original issue you should resolve
<issue_title>Concurrent tool calls on same session hang indefinitely (Dynamic GitLab API)</issue_title>
<issue_description>When using the Dynamic GitLab API, making concurrent tool calls with the same mcp-session-id causes the second (and subsequent) requests to hang indefinitely until timeout.
Expected Behavior
Both tool calls should complete successfully and return file contents.
Actual Behavior
First request completes successfully (returns file content)
Second request hangs indefinitely (no response)
After 60 seconds: McpError: MCP error -32001: Request timed out
script.js
script.js Output
mcp output