-
Notifications
You must be signed in to change notification settings - Fork 2.1k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
connection pool: max idle connections implementation #17443
connection pool: max idle connections implementation #17443
Conversation
Review ChecklistHello reviewers! 👋 Please follow this checklist when reviewing this Pull Request. General
Tests
Documentation
New flags
If a workflow is added or modified:
Backward compatibility
|
Codecov ReportAttention: Patch coverage is
Additional details and impacted files@@ Coverage Diff @@
## main #17443 +/- ##
==========================================
+ Coverage 67.68% 67.69% +0.01%
==========================================
Files 1584 1584
Lines 254466 254505 +39
==========================================
+ Hits 172235 172290 +55
+ Misses 82231 82215 -16 ☔ View full report in Codecov by Sentry. |
Signed-off-by: Harshit Gangal <harshit@planetscale.com>
Signed-off-by: Harshit Gangal <harshit@planetscale.com>
10025af
to
ea13abf
Compare
Signed-off-by: Harshit Gangal <harshit@planetscale.com>
Signed-off-by: Harshit Gangal <harshit@planetscale.com>
…lied to the pool Signed-off-by: Harshit Gangal <harshit@planetscale.com>
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
LGTM 👍
Signed-off-by: Harshit Gangal <harshit@planetscale.com>
Signed-off-by: Harshit Gangal <harshit@planetscale.com>
@@ -407,6 +432,23 @@ func (pool *ConnPool[C]) put(conn *Pooled[C]) { | |||
} | |||
} | |||
|
|||
// closeOnIdleLimitReached closes a connection if the number of idle connections (active - inuse) in the pool | |||
// exceeds the idleCount limit. It returns true if the connection is closed, false otherwise. | |||
func (pool *ConnPool[C]) closeOnIdleLimitReached(conn *Pooled[C]) bool { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Would it be better to not always immediately close, or just close with some random chance, so the connection churn is not really aggressive when there's high active transaction churn?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
We have to maintain a pool of some free available connections, otherwise there will be time spend in acquiring the connection for executing the query.
Even during high transactions, there will be log of get
and put
call that will happen on the pool, so we have to wait till the free connections become more than a certain limit before we start closing them.
Otherwise the application will see degradation in performance on high QPS
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Right, I said "not always". By which I meant, randomize closing after the idle time had reached.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Another way to look at it would be to make the idle time random, say between 1x and 2x of the config value, so we don't try and close lots of connections at the same time, after a spike in load.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
We already have support for idle time. This is implementation for idle count. You can choose to use either or both settings on the pool.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Yes, but the idle time and counts are hard thresholds, which will cause large numbers of connections to get closed at the same time, if a large number were opened at the same time, which is not necessary, and could be smoothed out a little.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
It is not like maximum connection lifetime which we already smooth out.
In case of idle connection, it is reasonable to churn them as and when they exceed the limit.
There is no active user looking for those connections, therefore they became idle.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
LGTM
Signed-off-by: Harshit Gangal <harshit@planetscale.com>
Description
This PR adds support for maximum idle connection in the pool.
The 3 pools gets it's own parameter for configuration:
queryserver-config-query-pool-max-idle-count
queryserver-config-stream-pool-max-idle-count
queryserver-config-txpool-max-idle-count
Related Issue(s)
Checklist
Deployment Notes