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
7f2632e6
Commit
7f2632e6
authored
Nov 09, 2021
by
Craig Miskell
Committed by
Marcel Amirault
Nov 09, 2021
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Update the sidekiq multi-process/concurrency docs
parent
fd23cb31
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
31 additions
and
8 deletions
+31
-8
doc/administration/operations/extra_sidekiq_processes.md
doc/administration/operations/extra_sidekiq_processes.md
+31
-8
No files found.
doc/administration/operations/extra_sidekiq_processes.md
View file @
7f2632e6
...
@@ -30,6 +30,11 @@ can be started.
...
@@ -30,6 +30,11 @@ can be started.
> - [Sidekiq cluster moved](https://gitlab.com/groups/gitlab-com/gl-infra/-/epics/181) to GitLab Free in 12.10.
> - [Sidekiq cluster moved](https://gitlab.com/groups/gitlab-com/gl-infra/-/epics/181) to GitLab Free in 12.10.
> - [Sidekiq cluster became default](https://gitlab.com/gitlab-org/omnibus-gitlab/-/merge_requests/4140) in GitLab 13.0.
> - [Sidekiq cluster became default](https://gitlab.com/gitlab-org/omnibus-gitlab/-/merge_requests/4140) in GitLab 13.0.
When starting multiple processes, the number of processes should
equal (and
**not**
exceed) the number of CPU cores you want to
dedicate to Sidekiq. Each Sidekiq process can use only 1 CPU
core, subject to the available workload and concurrency settings.
To start multiple processes:
To start multiple processes:
1.
Using the
`sidekiq['queue_groups']`
array setting, specify how many processes to
1.
Using the
`sidekiq['queue_groups']`
array setting, specify how many processes to
...
@@ -166,23 +171,41 @@ one only processes imports and the other processes all other queues:
...
@@ -166,23 +171,41 @@ one only processes imports and the other processes all other queues:
## Number of threads
## Number of threads
E
ach process defined under
`sidekiq`
starts with a
By default e
ach process defined under
`sidekiq`
starts with a
number of threads that equals the number of queues, plus one spare thread.
number of threads that equals the number of queues, plus one spare thread.
For example, a process that handles the
`process_commit`
and
`post_receive`
For example, a process that handles the
`process_commit`
and
`post_receive`
queues uses three threads in total.
queues uses three threads in total.
## Manage concurrency
These thread run inside a single Ruby process, and each process
can only use a single CPU core. The usefulness of threading depends
on the work having some external dependencies to wait on, like database queries or
HTTP requests. Most Sidekiq deployments benefit from this threading, and when
running fewer queues in a process, increasing the thread count might be
even more desirable to make the most effective use of CPU resources.
### Manage thread counts explicitly
The correct maximum thread count (also called concurrency) depends on the workload.
Typical values range from
`1`
for highly CPU-bound tasks to
`15`
or higher for mixed
low-priority work. A reasonable starting range is
`15`
to
`25`
for a non-specialized
deployment.
You can find example values used by GitLab.com by searching for
`concurrency:`
in
[
the Helm charts
](
https://gitlab.com/gitlab-com/gl-infra/k8s-workloads/gitlab-com/-/blob/master/releases/gitlab/values/gprd.yaml.gotmpl
)
.
The values vary according to the work each specific deployment of Sidekiq does.
Any other specialized deployments with processes dedicated to specific queues should
have the concurrency tuned according to:
have the concurrency tuned according to:
When setting the maximum concurrency, keep in mind this normally should
-
The CPU usage of each type of process.
not exceed the number of CPU cores available. The values in the examples
-
The throughput achieved.
below are arbitrary and not particular recommendations.
Each thread requires a Redis connection, so adding threads may increase Redis
Each thread requires a Redis connection, so adding threads may increase Redis
latency and potentially cause client timeouts. See the
[
Sidekiq documentation
latency and potentially cause client timeouts. See the
[
Sidekiq documentation
about Redis
](
https://github.com/mperham/sidekiq/wiki/Using-Redis
)
for more
about Redis
](
https://github.com/mperham/sidekiq/wiki/Using-Redis
)
for more
details.
details.
### When running Sidekiq cluster (default)
###
#
When running Sidekiq cluster (default)
Running Sidekiq cluster is the default in GitLab 13.0 and later.
Running Sidekiq cluster is the default in GitLab 13.0 and later.
...
@@ -203,7 +226,7 @@ Running Sidekiq cluster is the default in GitLab 13.0 and later.
...
@@ -203,7 +226,7 @@ Running Sidekiq cluster is the default in GitLab 13.0 and later.
the other. Setting
`min_concurrency`
to
`0`
disables the limit.
the other. Setting
`min_concurrency`
to
`0`
disables the limit.
For each queue group, let
`N`
be one more than the number of queues. The
For each queue group, let
`N`
be one more than the number of queues. The
concurrency
factor are
set to:
concurrency
is
set to:
1.
`N`
, if it's between
`min_concurrency`
and
`max_concurrency`
.
1.
`N`
, if it's between
`min_concurrency`
and
`max_concurrency`
.
1.
`max_concurrency`
, if
`N`
exceeds this value.
1.
`max_concurrency`
, if
`N`
exceeds this value.
...
@@ -215,7 +238,7 @@ regardless of the number of queues.
...
@@ -215,7 +238,7 @@ regardless of the number of queues.
When
`min_concurrency`
is greater than
`max_concurrency`
, it is treated as
When
`min_concurrency`
is greater than
`max_concurrency`
, it is treated as
being equal to
`max_concurrency`
.
being equal to
`max_concurrency`
.
### When running a single Sidekiq process
###
#
When running a single Sidekiq process
Running a single Sidekiq process is the default in GitLab 12.10 and earlier.
Running a single Sidekiq process is the default in GitLab 12.10 and earlier.
...
...
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