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
28094a62
Commit
28094a62
authored
Jul 08, 2021
by
Piotr Skorupa
Committed by
Matthias Käppler
Jul 08, 2021
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Rename GitlabUsagePingWorker
parent
0d4e9458
Changes
12
Hide whitespace changes
Inline
Side-by-side
Showing
12 changed files
with
115 additions
and
31 deletions
+115
-31
.rubocop_manual_todo.yml
.rubocop_manual_todo.yml
+1
-0
app/workers/all_queues.yml
app/workers/all_queues.yml
+9
-0
app/workers/gitlab_service_ping_worker.rb
app/workers/gitlab_service_ping_worker.rb
+28
-0
app/workers/gitlab_usage_ping_worker.rb
app/workers/gitlab_usage_ping_worker.rb
+1
-25
config/initializers/1_settings.rb
config/initializers/1_settings.rb
+3
-0
config/settings.rb
config/settings.rb
+2
-2
db/migrate/20210617180131_migrate_usage_ping_sidekiq_queue.rb
...igrate/20210617180131_migrate_usage_ping_sidekiq_queue.rb
+15
-0
db/schema_migrations/20210617180131
db/schema_migrations/20210617180131
+1
-0
lib/tasks/gitlab/usage_data.rake
lib/tasks/gitlab/usage_data.rake
+1
-1
spec/config/settings_spec.rb
spec/config/settings_spec.rb
+3
-3
spec/workers/every_sidekiq_worker_spec.rb
spec/workers/every_sidekiq_worker_spec.rb
+1
-0
spec/workers/gitlab_service_ping_worker_spec.rb
spec/workers/gitlab_service_ping_worker_spec.rb
+50
-0
No files found.
.rubocop_manual_todo.yml
View file @
28094a62
...
@@ -1756,6 +1756,7 @@ Gitlab/NamespacedClass:
...
@@ -1756,6 +1756,7 @@ Gitlab/NamespacedClass:
-
'
app/workers/git_garbage_collect_worker.rb'
-
'
app/workers/git_garbage_collect_worker.rb'
-
'
app/workers/gitlab_performance_bar_stats_worker.rb'
-
'
app/workers/gitlab_performance_bar_stats_worker.rb'
-
'
app/workers/gitlab_shell_worker.rb'
-
'
app/workers/gitlab_shell_worker.rb'
-
'
app/workers/gitlab_service_ping_worker.rb'
-
'
app/workers/gitlab_usage_ping_worker.rb'
-
'
app/workers/gitlab_usage_ping_worker.rb'
-
'
app/workers/group_destroy_worker.rb'
-
'
app/workers/group_destroy_worker.rb'
-
'
app/workers/group_export_worker.rb'
-
'
app/workers/group_export_worker.rb'
...
...
app/workers/all_queues.yml
View file @
28094a62
...
@@ -265,6 +265,15 @@
...
@@ -265,6 +265,15 @@
:weight:
1
:weight:
1
:idempotent:
:idempotent:
:tags: []
:tags: []
-
:name: cronjob:gitlab_service_ping
:worker_name: GitlabServicePingWorker
:feature_category: :service_ping
:has_external_dependencies:
:urgency: :low
:resource_boundary: :unknown
:weight:
1
:idempotent:
:tags: []
-
:name: cronjob:gitlab_usage_ping
-
:name: cronjob:gitlab_usage_ping
:worker_name: GitlabUsagePingWorker
:worker_name: GitlabUsagePingWorker
:feature_category: :service_ping
:feature_category: :service_ping
...
...
app/workers/gitlab_service_ping_worker.rb
0 → 100644
View file @
28094a62
# frozen_string_literal: true
class
GitlabServicePingWorker
# rubocop:disable Scalability/IdempotentWorker
LEASE_KEY
=
'gitlab_service_ping_worker:ping'
LEASE_TIMEOUT
=
86400
include
ApplicationWorker
include
CronjobQueue
# rubocop:disable Scalability/CronWorkerContext
include
Gitlab
::
ExclusiveLeaseHelpers
feature_category
:service_ping
sidekiq_options
retry:
3
,
dead:
false
sidekiq_retry_in
{
|
count
|
(
count
+
1
)
*
8
.
hours
.
to_i
}
def
perform
# Disable service ping for GitLab.com
# See https://gitlab.com/gitlab-org/gitlab/-/issues/292929 for details
return
if
Gitlab
.
com?
# Multiple Sidekiq workers could run this. We should only do this at most once a day.
in_lock
(
LEASE_KEY
,
ttl:
LEASE_TIMEOUT
)
do
# Splay the request over a minute to avoid thundering herd problems.
sleep
(
rand
(
0.0
..
60.0
).
round
(
3
))
ServicePing
::
SubmitService
.
new
.
execute
end
end
end
app/workers/gitlab_usage_ping_worker.rb
View file @
28094a62
# frozen_string_literal: true
# frozen_string_literal: true
class
GitlabUsagePingWorker
# rubocop:disable Scalability/IdempotentWorker
class
GitlabUsagePingWorker
<
GitlabServicePingWorker
# rubocop:disable Scalability/IdempotentWorker
LEASE_KEY
=
'gitlab_usage_ping_worker:ping'
LEASE_TIMEOUT
=
86400
include
ApplicationWorker
include
CronjobQueue
# rubocop:disable Scalability/CronWorkerContext
include
Gitlab
::
ExclusiveLeaseHelpers
feature_category
:service_ping
sidekiq_options
retry:
3
,
dead:
false
sidekiq_retry_in
{
|
count
|
(
count
+
1
)
*
8
.
hours
.
to_i
}
def
perform
# Disable usage ping for GitLab.com
# See https://gitlab.com/gitlab-org/gitlab/-/issues/292929 for details
return
if
Gitlab
.
com?
# Multiple Sidekiq workers could run this. We should only do this at most once a day.
in_lock
(
LEASE_KEY
,
ttl:
LEASE_TIMEOUT
)
do
# Splay the request over a minute to avoid thundering herd problems.
sleep
(
rand
(
0.0
..
60.0
).
round
(
3
))
ServicePing
::
SubmitService
.
new
.
execute
end
end
end
end
config/initializers/1_settings.rb
View file @
28094a62
...
@@ -501,6 +501,9 @@ Settings.cron_jobs['stuck_export_jobs_worker']['job_class'] = 'StuckExportJobsWo
...
@@ -501,6 +501,9 @@ Settings.cron_jobs['stuck_export_jobs_worker']['job_class'] = 'StuckExportJobsWo
Settings
.
cron_jobs
[
'gitlab_usage_ping_worker'
]
||=
Settingslogic
.
new
({})
Settings
.
cron_jobs
[
'gitlab_usage_ping_worker'
]
||=
Settingslogic
.
new
({})
Settings
.
cron_jobs
[
'gitlab_usage_ping_worker'
][
'cron'
]
||=
nil
# This is dynamically loaded in the sidekiq initializer
Settings
.
cron_jobs
[
'gitlab_usage_ping_worker'
][
'cron'
]
||=
nil
# This is dynamically loaded in the sidekiq initializer
Settings
.
cron_jobs
[
'gitlab_usage_ping_worker'
][
'job_class'
]
=
'GitlabUsagePingWorker'
Settings
.
cron_jobs
[
'gitlab_usage_ping_worker'
][
'job_class'
]
=
'GitlabUsagePingWorker'
Settings
.
cron_jobs
[
'gitlab_service_ping_worker'
]
||=
Settingslogic
.
new
({})
Settings
.
cron_jobs
[
'gitlab_service_ping_worker'
][
'cron'
]
||=
nil
# This is dynamically loaded in the sidekiq initializer
Settings
.
cron_jobs
[
'gitlab_service_ping_worker'
][
'job_class'
]
=
'GitlabServicePingWorker'
Settings
.
cron_jobs
[
'stuck_merge_jobs_worker'
]
||=
Settingslogic
.
new
({})
Settings
.
cron_jobs
[
'stuck_merge_jobs_worker'
]
||=
Settingslogic
.
new
({})
Settings
.
cron_jobs
[
'stuck_merge_jobs_worker'
][
'cron'
]
||=
'0 */2 * * *'
Settings
.
cron_jobs
[
'stuck_merge_jobs_worker'
][
'cron'
]
||=
'0 */2 * * *'
Settings
.
cron_jobs
[
'stuck_merge_jobs_worker'
][
'job_class'
]
=
'StuckMergeJobsWorker'
Settings
.
cron_jobs
[
'stuck_merge_jobs_worker'
][
'job_class'
]
=
'StuckMergeJobsWorker'
...
...
config/settings.rb
View file @
28094a62
...
@@ -163,7 +163,7 @@ class Settings < Settingslogic
...
@@ -163,7 +163,7 @@ class Settings < Settingslogic
end
end
def
load_dynamic_cron_schedules!
def
load_dynamic_cron_schedules!
cron_jobs
[
'gitlab_
usage_ping_worker'
][
'cron'
]
||=
cron_for_usag
e_ping
cron_jobs
[
'gitlab_
service_ping_worker'
][
'cron'
]
||=
cron_for_servic
e_ping
end
end
private
private
...
@@ -197,7 +197,7 @@ class Settings < Settingslogic
...
@@ -197,7 +197,7 @@ class Settings < Settingslogic
# Runs at a consistent random time of day on a day of the week based on
# Runs at a consistent random time of day on a day of the week based on
# the instance UUID. This is to balance the load on the service receiving
# the instance UUID. This is to balance the load on the service receiving
# these pings. The sidekiq job handles temporary http failures.
# these pings. The sidekiq job handles temporary http failures.
def
cron_for_
usag
e_ping
def
cron_for_
servic
e_ping
# Set a default UUID for the case when the UUID hasn't been initialized.
# Set a default UUID for the case when the UUID hasn't been initialized.
uuid
=
Gitlab
::
CurrentSettings
.
uuid
||
'uuid-not-set'
uuid
=
Gitlab
::
CurrentSettings
.
uuid
||
'uuid-not-set'
...
...
db/migrate/20210617180131_migrate_usage_ping_sidekiq_queue.rb
0 → 100644
View file @
28094a62
# frozen_string_literal: true
class
MigrateUsagePingSidekiqQueue
<
ActiveRecord
::
Migration
[
6.1
]
include
Gitlab
::
Database
::
MigrationHelpers
# rubocop:disable Migration/SidekiqQueueMigrate
def
up
sidekiq_queue_migrate
'cronjob:gitlab_usage_ping'
,
to:
'cronjob:gitlab_service_ping'
end
def
down
sidekiq_queue_migrate
'cronjob:gitlab_service_ping'
,
to:
'cronjob:gitlab_usage_ping'
end
# rubocop:enable Migration/SidekiqQueueMigrate
end
db/schema_migrations/20210617180131
0 → 100644
View file @
28094a62
2adb38e71c6173350d1f98f3237b692e4f12c8a073115be23f3a713f69cde911
\ No newline at end of file
lib/tasks/gitlab/usage_data.rake
View file @
28094a62
...
@@ -19,7 +19,7 @@ namespace :gitlab do
...
@@ -19,7 +19,7 @@ namespace :gitlab do
desc
'GitLab | UsageData | Generate usage ping and send it to Versions Application'
desc
'GitLab | UsageData | Generate usage ping and send it to Versions Application'
task
generate_and_send: :environment
do
task
generate_and_send: :environment
do
result
=
S
ubmitUsagePing
Service
.
new
.
execute
result
=
S
ervicePing
::
Submit
Service
.
new
.
execute
puts
Gitlab
::
Json
.
pretty_generate
(
result
.
attributes
)
puts
Gitlab
::
Json
.
pretty_generate
(
result
.
attributes
)
end
end
...
...
spec/config/settings_spec.rb
View file @
28094a62
...
@@ -113,12 +113,12 @@ RSpec.describe Settings do
...
@@ -113,12 +113,12 @@ RSpec.describe Settings do
end
end
end
end
describe
'.cron_for_
usag
e_ping'
do
describe
'.cron_for_
servic
e_ping'
do
it
'returns correct crontab for some manually calculated example'
do
it
'returns correct crontab for some manually calculated example'
do
allow
(
Gitlab
::
CurrentSettings
)
allow
(
Gitlab
::
CurrentSettings
)
.
to
receive
(
:uuid
)
{
'd9e2f4e8-db1f-4e51-b03d-f427e1965c4a'
}
.
to
receive
(
:uuid
)
{
'd9e2f4e8-db1f-4e51-b03d-f427e1965c4a'
}
expect
(
described_class
.
send
(
:cron_for_
usag
e_ping
)).
to
eq
(
'21 18 * * 4'
)
expect
(
described_class
.
send
(
:cron_for_
servic
e_ping
)).
to
eq
(
'21 18 * * 4'
)
end
end
it
'returns min, hour, day in the valid range'
do
it
'returns min, hour, day in the valid range'
do
...
@@ -126,7 +126,7 @@ RSpec.describe Settings do
...
@@ -126,7 +126,7 @@ RSpec.describe Settings do
.
to
receive
(
:uuid
)
{
SecureRandom
.
uuid
}
.
to
receive
(
:uuid
)
{
SecureRandom
.
uuid
}
10
.
times
do
10
.
times
do
cron
=
described_class
.
send
(
:cron_for_
usag
e_ping
).
split
(
/\s/
)
cron
=
described_class
.
send
(
:cron_for_
servic
e_ping
).
split
(
/\s/
)
expect
(
cron
[
0
].
to_i
).
to
be_between
(
0
,
59
)
expect
(
cron
[
0
].
to_i
).
to
be_between
(
0
,
59
)
expect
(
cron
[
1
].
to_i
).
to
be_between
(
0
,
23
)
expect
(
cron
[
1
].
to_i
).
to
be_between
(
0
,
23
)
...
...
spec/workers/every_sidekiq_worker_spec.rb
View file @
28094a62
...
@@ -287,6 +287,7 @@ RSpec.describe 'Every Sidekiq worker' do
...
@@ -287,6 +287,7 @@ RSpec.describe 'Every Sidekiq worker' do
'Gitlab::PhabricatorImport::ImportTasksWorker'
=>
5
,
'Gitlab::PhabricatorImport::ImportTasksWorker'
=>
5
,
'GitlabPerformanceBarStatsWorker'
=>
3
,
'GitlabPerformanceBarStatsWorker'
=>
3
,
'GitlabShellWorker'
=>
3
,
'GitlabShellWorker'
=>
3
,
'GitlabServicePingWorker'
=>
3
,
'GitlabUsagePingWorker'
=>
3
,
'GitlabUsagePingWorker'
=>
3
,
'GroupDestroyWorker'
=>
3
,
'GroupDestroyWorker'
=>
3
,
'GroupExportWorker'
=>
false
,
'GroupExportWorker'
=>
false
,
...
...
spec/workers/gitlab_service_ping_worker_spec.rb
0 → 100644
View file @
28094a62
# frozen_string_literal: true
require
'spec_helper'
RSpec
.
describe
GitlabServicePingWorker
,
:clean_gitlab_redis_shared_state
do
before
do
allow_next_instance_of
(
ServicePing
::
SubmitService
)
{
|
service
|
allow
(
service
).
to
receive
(
:execute
)
}
allow
(
subject
).
to
receive
(
:sleep
)
end
it
'does not run for GitLab.com'
do
allow
(
Gitlab
).
to
receive
(
:com?
).
and_return
(
true
)
expect
(
ServicePing
::
SubmitService
).
not_to
receive
(
:new
)
subject
.
perform
end
it
'delegates to ServicePing::SubmitService'
do
expect_next_instance_of
(
ServicePing
::
SubmitService
)
{
|
service
|
expect
(
service
).
to
receive
(
:execute
)
}
subject
.
perform
end
it
"obtains a
#{
described_class
::
LEASE_TIMEOUT
}
second exclusive lease"
do
expect
(
Gitlab
::
ExclusiveLeaseHelpers
::
SleepingLock
)
.
to
receive
(
:new
)
.
with
(
described_class
::
LEASE_KEY
,
hash_including
(
timeout:
described_class
::
LEASE_TIMEOUT
))
.
and_call_original
subject
.
perform
end
it
'sleeps for between 0 and 60 seconds'
do
expect
(
subject
).
to
receive
(
:sleep
).
with
(
0
..
60
)
subject
.
perform
end
context
'when lease is not obtained'
do
before
do
Gitlab
::
ExclusiveLease
.
new
(
described_class
::
LEASE_KEY
,
timeout:
described_class
::
LEASE_TIMEOUT
).
try_obtain
end
it
'does not invoke ServicePing::SubmitService'
do
allow_next_instance_of
(
ServicePing
::
SubmitService
)
{
|
service
|
expect
(
service
).
not_to
receive
(
:execute
)
}
expect
{
subject
.
perform
}.
to
raise_error
(
Gitlab
::
ExclusiveLeaseHelpers
::
FailedToObtainLockError
)
end
end
end
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