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
07c1b494
Commit
07c1b494
authored
Dec 23, 2021
by
Bob Van Landuyt
Committed by
Amy Qualls
Dec 23, 2021
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Explain queue routing behaviour in GDK
parent
6147e3b5
Changes
1
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
13 additions
and
6 deletions
+13
-6
doc/development/sidekiq_style_guide.md
doc/development/sidekiq_style_guide.md
+13
-6
No files found.
doc/development/sidekiq_style_guide.md
View file @
07c1b494
...
...
@@ -13,7 +13,7 @@ modifying Sidekiq workers.
All workers should include
`ApplicationWorker`
instead of
`Sidekiq::Worker`
,
which adds some convenience methods and automatically sets the queue based on
the
worker's name
.
the
[
routing rules
](
../administration/operations/extra_sidekiq_routing.md#queue-routing-rules
)
.
## Retries
...
...
@@ -45,19 +45,26 @@ Each retry for a worker is counted as a failure in our metrics. A worker
which always fails 9 times and succeeds on the 10th would have a 90%
error rate.
##
Dedicated
Queues
##
Sidekiq
Queues
All workers should use their own queue, which i
s automatically set based on the
Previously, each worker had its own queue, which wa
s automatically set based on the
worker class name. For a worker named
`ProcessSomethingWorker`
, the queue name
would be
`process_something`
. If you're not sure what queue a worker uses,
would be
`process_something`
. You can now route workers to a specific queue using
[
queue routing rules
](
../administration/operations/extra_sidekiq_routing.md#queue-routing-rules
)
.
In GDK, new workers are routed to a queue named
`default`
.
If you're not sure what queue a worker uses,
you can find it using
`SomeWorker.queue`
. There is almost never a reason to
manually override the queue name using
`sidekiq_options queue: :some_queue`
.
After adding a new
queue
, run
`bin/rake
After adding a new
worker
, run
`bin/rake
gitlab:sidekiq:all_queues_yml:generate`
to regenerate
`app/workers/all_queues.yml`
or
`ee/app/workers/all_queues.yml`
so that
it can be picked up by
[
`sidekiq-cluster`
](
../administration/operations/extra_sidekiq_processes.md
)
.
[
`sidekiq-cluster`
](
../administration/operations/extra_sidekiq_processes.md
)
in installations that don't use routing rules. To learn more about potential changes,
read
[
Use routing rules by default and deprecate queue selectors for self-managed
](
https://gitlab.com/groups/gitlab-com/gl-infra/-/epics/596
)
.
Additionally, run
`bin/rake gitlab:sidekiq:sidekiq_queues_yml:generate`
to regenerate
`config/sidekiq_queues.yml`
.
...
...
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