Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
G
gitlab-ce
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
1
Merge Requests
1
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
nexedi
gitlab-ce
Commits
ac9b5d2a
Commit
ac9b5d2a
authored
Jul 22, 2020
by
Jacob Vosmaer
Committed by
Bob Van Landuyt
Jul 22, 2020
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Simplify DB connection pool size configuration (optional)
parent
32728831
Changes
3
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
114 additions
and
5 deletions
+114
-5
config/initializers/database_config.rb
config/initializers/database_config.rb
+38
-5
ee/spec/initializers/database_config_spec.rb
ee/spec/initializers/database_config_spec.rb
+22
-0
spec/initializers/database_config_spec.rb
spec/initializers/database_config_spec.rb
+54
-0
No files found.
config/initializers/database_config.rb
View file @
ac9b5d2a
...
@@ -20,11 +20,44 @@ Gitlab.ee do
...
@@ -20,11 +20,44 @@ Gitlab.ee do
end
end
end
end
# When running on multi-threaded runtimes like Puma or Sidekiq,
# TODO get rid of feature flag https://gitlab.com/gitlab-com/gl-infra/scalability/-/issues/495
# set the number of threads per process as the minimum DB connection pool size.
if
ENV
[
'DB_USE_NEW_POOL_SIZE_LOGIC'
]
==
'1'
# This is to avoid connectivity issues as was documented here:
# Because of the way Ruby on Rails manages database connections, it is
# https://github.com/rails/rails/pull/23057
# important that we have at least as many connections as we have
if
Gitlab
::
Runtime
.
multi_threaded?
# threads. While there is a 'pool' setting in database.yml, it is not
# very practical because you need to maintain it in tandem with the
# number of application threads. Because of this we override the number
# of allowed connections in the database connection pool based on the
# configured number of application threads.
#
# Gitlab::Runtime.max_threads is the number of "user facing" application
# threads the process has been configured with. We also have auxiliary
# threads that use database connections. Because it is not practical to
# keep an accurate count of the number auxiliary threads as the
# application evolves over time, we just add a fixed headroom to the
# number of user-facing threads. It is OK if this number is too large
# because connections are instantiated lazily.
headroom
=
(
ENV
[
"DB_POOL_HEADROOM"
].
presence
||
10
).
to_i
calculated_pool_size
=
Gitlab
::
Runtime
.
max_threads
+
headroom
db_config
=
Gitlab
::
Database
.
config
||
Rails
.
application
.
config
.
database_configuration
[
Rails
.
env
]
db_config
[
'pool'
]
=
calculated_pool_size
ActiveRecord
::
Base
.
establish_connection
(
db_config
)
Gitlab
.
ee
do
if
Gitlab
::
Runtime
.
sidekiq?
&&
Gitlab
::
Geo
.
geo_database_configured?
Rails
.
configuration
.
geo_database
[
'pool'
]
=
calculated_pool_size
Geo
::
TrackingBase
.
establish_connection
(
Rails
.
configuration
.
geo_database
)
end
end
elsif
Gitlab
::
Runtime
.
multi_threaded?
# When running on multi-threaded runtimes like Puma or Sidekiq,
# set the number of threads per process as the minimum DB connection pool size.
# This is to avoid connectivity issues as was documented here:
# https://github.com/rails/rails/pull/23057
max_threads
=
Gitlab
::
Runtime
.
max_threads
max_threads
=
Gitlab
::
Runtime
.
max_threads
db_config
=
Gitlab
::
Database
.
config
||
db_config
=
Gitlab
::
Database
.
config
||
Rails
.
application
.
config
.
database_configuration
[
Rails
.
env
]
Rails
.
application
.
config
.
database_configuration
[
Rails
.
env
]
...
...
ee/spec/initializers/database_config_spec.rb
View file @
ac9b5d2a
...
@@ -39,6 +39,28 @@ RSpec.describe 'Database config initializer for GitLab EE' do
...
@@ -39,6 +39,28 @@ RSpec.describe 'Database config initializer for GitLab EE' do
end
end
end
end
context
"with new pool size logic"
do
let
(
:max_threads
)
{
8
}
before
do
stub_env
(
'DB_USE_NEW_POOL_SIZE_LOGIC'
,
'1'
)
allow
(
Gitlab
::
Runtime
).
to
receive
(
:max_threads
).
and_return
(
max_threads
)
allow
(
ActiveRecord
::
Base
).
to
receive
(
:establish_connection
)
expect
(
Geo
::
TrackingBase
).
to
receive
(
:establish_connection
)
end
context
"and the runtime is Sidekiq"
do
before
do
allow
(
Gitlab
::
Runtime
).
to
receive
(
:sidekiq?
).
and_return
(
true
)
end
it
"sets Geo DB connection pool size to the max number of worker threads"
do
expect
{
subject
}.
to
change
{
Rails
.
configuration
.
geo_database
[
'pool'
]
}.
from
(
1
).
to
(
18
)
end
end
end
def
stub_geo_database_config
(
pool_size
:)
def
stub_geo_database_config
(
pool_size
:)
config
=
{
config
=
{
'adapter'
=>
'postgresql'
,
'adapter'
=>
'postgresql'
,
...
...
spec/initializers/database_config_spec.rb
View file @
ac9b5d2a
...
@@ -71,6 +71,60 @@ RSpec.describe 'Database config initializer' do
...
@@ -71,6 +71,60 @@ RSpec.describe 'Database config initializer' do
end
end
end
end
context
"with new pool size logic"
do
let
(
:max_threads
)
{
8
}
before
do
stub_env
(
'DB_USE_NEW_POOL_SIZE_LOGIC'
,
'1'
)
allow
(
Gitlab
::
Runtime
).
to
receive
(
:max_threads
).
and_return
(
max_threads
)
end
context
"and no existing pool size is set"
do
before
do
stub_database_config
(
pool_size:
nil
)
end
it
"sets it based on the max number of worker threads"
do
expect
{
subject
}.
to
change
{
Gitlab
::
Database
.
config
[
'pool'
]
}.
from
(
nil
).
to
(
18
)
end
end
context
"and the existing pool size is smaller than the max number of worker threads"
do
before
do
stub_database_config
(
pool_size:
1
)
end
it
"sets it based on the max number of worker threads"
do
expect
{
subject
}.
to
change
{
Gitlab
::
Database
.
config
[
'pool'
]
}.
from
(
1
).
to
(
18
)
end
end
context
"and the existing pool size is larger than the max number of worker threads"
do
before
do
stub_database_config
(
pool_size:
100
)
end
it
"sets it based on the max number of worker threads"
do
expect
{
subject
}.
to
change
{
Gitlab
::
Database
.
config
[
'pool'
]
}.
from
(
100
).
to
(
18
)
end
end
context
"when specifying headroom through an ENV variable"
do
let
(
:headroom
)
{
15
}
before
do
stub_database_config
(
pool_size:
1
)
stub_env
(
"DB_POOL_HEADROOM"
,
headroom
)
end
it
"adds headroom on top of the calculated size"
do
expect
{
subject
}.
to
change
{
Gitlab
::
Database
.
config
[
'pool'
]
}
.
from
(
1
)
.
to
(
max_threads
+
headroom
)
end
end
end
def
stub_database_config
(
pool_size
:)
def
stub_database_config
(
pool_size
:)
config
=
{
config
=
{
'adapter'
=>
'postgresql'
,
'adapter'
=>
'postgresql'
,
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment