Skip to content

Conversation

@mdaigle
Copy link
Contributor

@mdaigle mdaigle commented Mar 5, 2025

Introduces an abstract class to capture the API of the current connection pool implementation. Gathers pooling related classes into a single namespace (Microsoft.Data.SqlClient.ConnectionPool) and folder. These changes set the stage for swappable connection pool implementations. Targeting main because these are good standalone changes for code cleanliness. Future changes will target a feature branch.

This work is tracking against #25

PoolBlockingPeriod is not moved because it is public. Moving it's location/namespace would be a breaking API change. It may still make sense to switch its namespace if this can go in with a major version bump.

@mdaigle mdaigle changed the title Modular connection pool Refactor for modular connection pool Mar 5, 2025
@mdaigle
Copy link
Contributor Author

mdaigle commented Mar 5, 2025

/azp run

@azure-pipelines
Copy link

Azure Pipelines successfully started running 1 pipeline(s).

@codecov
Copy link

codecov bot commented Mar 6, 2025

Codecov Report

Attention: Patch coverage is 84.00000% with 12 lines in your changes missing coverage. Please review.

Project coverage is 65.96%. Comparing base (3f4e486) to head (b7a321e).
Report is 6 commits behind head on main.

Files with missing lines Patch % Lines
...lient/ConnectionPool/WaitHandleDbConnectionPool.cs 82.35% 12 Missing ⚠️

❗ There is a different number of reports uploaded between BASE (3f4e486) and HEAD (b7a321e). Click for more details.

HEAD has 1 upload less than BASE
Flag BASE (3f4e486) HEAD (b7a321e)
addons 1 0
Additional details and impacted files
@@            Coverage Diff             @@
##             main    #3199      +/-   ##
==========================================
- Coverage   72.89%   65.96%   -6.94%     
==========================================
  Files         288      283       -5     
  Lines       59246    59209      -37     
==========================================
- Hits        43190    39055    -4135     
- Misses      16056    20154    +4098     
Flag Coverage Δ
addons ?
netcore 68.82% <83.09%> (-6.69%) ⬇️
netfx 64.87% <84.00%> (-6.41%) ⬇️

Flags with carried forward coverage won't be shown. Click here to find out more.

☔ View full report in Codecov by Sentry.
📢 Have feedback on the report? Share it here.

🚀 New features to boost your workflow:
  • Test Analytics: Detect flaky tests, report on failures, and find test suite problems.

@mdaigle mdaigle changed the base branch from main to dev/mdaigle/connection-pool-perf March 6, 2025 19:45
@mdaigle mdaigle marked this pull request as ready for review March 6, 2025 19:45
@mdaigle mdaigle changed the base branch from dev/mdaigle/connection-pool-perf to main March 6, 2025 19:47
@mdaigle mdaigle requested a review from Copilot March 6, 2025 20:06
Copy link
Contributor

Copilot AI left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

PR Overview

This PR refactors the connection pool implementation to be more modular by introducing an abstract DbConnectionPool class and moving pooling-related classes into the Microsoft.Data.SqlClient.ConnectionPool namespace.

  • Introduces a new abstract class (DbConnectionPool) that captures the current connection pool API.
  • Migrates several classes from Microsoft.Data.ProviderBase to Microsoft.Data.SqlClient.ConnectionPool.
  • Updates pool instantiation in DbConnectionPoolGroup to use WaitHandleDbConnectionPool, supporting modular and swappable implementations.

Reviewed Changes

File Description
src/Microsoft.Data.SqlClient/src/Microsoft/Data/SqlClient/ConnectionPool/DbConnectionPool.cs Adds a new abstract base class for connection pooling API.
src/Microsoft.Data.SqlClient/src/Microsoft/Data/SqlClient/ConnectionPool/DbConnectionPoolCounters.netfx.cs Updates the namespace to the new connection pool namespace.
src/Microsoft.Data.SqlClient/netfx/src/Microsoft/Data/SqlClient/SqlConnectionHelper.cs Adapts references from the old provider base pool group to the new connection pool group.
src/Microsoft.Data.SqlClient/src/Microsoft/Data/SqlClient/ConnectionPool/DbConnectionPoolIdentity.Unix.cs Updates namespace from ProviderBase to SqlClient.ConnectionPool.
src/Microsoft.Data.SqlClient/src/Microsoft/Data/SqlClient/ConnectionPool/DbConnectionPoolAuthenticationContextKey.cs Updates namespace from ProviderBase to SqlClient.ConnectionPool.
src/Microsoft.Data.SqlClient/src/Microsoft/Data/SqlClient/ConnectionPool/DbConnectionPoolGroupProviderInfo.cs Updates namespace from ProviderBase to SqlClient.ConnectionPool.
src/Microsoft.Data.SqlClient/src/Microsoft/Data/SqlClient/ConnectionPool/DbConnectionPoolAuthenticationContext.cs Updates namespace from ProviderBase to SqlClient.ConnectionPool.
src/Microsoft.Data.SqlClient/src/Microsoft/Data/SqlClient/ConnectionPool/DbConnectionPoolGroup.cs Modifies pool instantiation to use WaitHandleDbConnectionPool.
src/Microsoft.Data.SqlClient/netcore/src/Microsoft/Data/SqlClient/SqlConnectionFactory.cs Incorporates the new connection pool namespace in factory logic.
src/Microsoft.Data.SqlClient/src/Microsoft/Data/ProviderBase/DbConnectionFactory.cs Updates pool group references to use the new connection pool namespace.
src/Microsoft.Data.SqlClient/netfx/src/Microsoft/Data/SqlClient/SqlConnectionFactory.cs Updates pool group references to use the new connection pool namespace.
src/Microsoft.Data.SqlClient/src/Microsoft/Data/ProviderBase/DbConnectionInternal.cs Adapts using statements to include the new connection pool namespace.
src/Microsoft.Data.SqlClient/netcore/src/Microsoft/Data/SqlClient/SqlConnectionHelper.cs Updates namespace references accordingly.
src/Microsoft.Data.SqlClient/src/Microsoft/Data/ProviderBase/DbConnectionClosed.cs Updates namespace to use the new connection pool namespace.
src/Microsoft.Data.SqlClient/netcore/src/Microsoft/Data/SqlClient/SqlInternalConnectionTds.cs Updates namespace to include the new connection pool namespace.
src/Microsoft.Data.SqlClient/netfx/src/Microsoft/Data/SqlClient/SqlConnection.cs Updates namespace imports accordingly.
src/Microsoft.Data.SqlClient/netcore/src/Microsoft/Data/SqlClient/SqlConnection.cs Updates namespace imports accordingly.
src/Microsoft.Data.SqlClient/netfx/src/Microsoft/Data/SqlClient/SqlInternalConnectionTds.cs Updates namespace imports accordingly.

Copilot reviewed 33 out of 33 changed files in this pull request and generated no comments.

Comments suppressed due to low confidence (1)

src/Microsoft.Data.SqlClient/src/Microsoft/Data/SqlClient/ConnectionPool/DbConnectionPoolGroup.cs:190

  • Please ensure that the new WaitHandleDbConnectionPool implementation is thoroughly tested to validate its initialization, cleanup, and overall behavior in the connection pool lifecycle.
DbConnectionPool newPool = new WaitHandleDbConnectionPool(connectionFactory, this, currentIdentity, connectionPoolProviderInfo);

Copy link
Contributor

@benrr101 benrr101 left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Overall I like these changes. Mostly stylistic changes I'm requesting, a couple bigger questions around what the longer term plan is.

@mdaigle mdaigle requested a review from a team March 6, 2025 23:12
Copy link
Contributor

@benrr101 benrr101 left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Looks much better now, thanks!

This was referenced Oct 6, 2025
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

3 participants