2018-11-08 19:23:39 +05:30
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2020-04-08 14:13:33 +05:30
|
|
|
class ReactiveCachingWorker # rubocop:disable Scalability/IdempotentWorker
|
2018-03-17 18:26:18 +05:30
|
|
|
include ApplicationWorker
|
2017-08-17 22:00:37 +05:30
|
|
|
|
2019-12-21 20:55:43 +05:30
|
|
|
feature_category_not_owned!
|
|
|
|
|
2019-12-26 22:10:19 +05:30
|
|
|
# TODO: The reactive caching worker should be split into
|
2020-04-08 14:13:33 +05:30
|
|
|
# two different workers, one for high urgency jobs without external dependencies
|
|
|
|
# and another worker without high urgency, but with external dependencies
|
2019-12-26 22:10:19 +05:30
|
|
|
# https://gitlab.com/gitlab-com/gl-infra/scalability/issues/34
|
|
|
|
# This worker should also have `worker_has_external_dependencies!` enabled
|
2020-04-08 14:13:33 +05:30
|
|
|
urgency :high
|
2019-12-26 22:10:19 +05:30
|
|
|
worker_resource_boundary :cpu
|
|
|
|
|
2020-04-22 19:07:51 +05:30
|
|
|
def self.context_for_arguments(arguments)
|
|
|
|
class_name, *_other_args = arguments
|
|
|
|
Gitlab::ApplicationContext.new(related_class: class_name.to_s)
|
|
|
|
end
|
|
|
|
|
2017-08-17 22:00:37 +05:30
|
|
|
def perform(class_name, id, *args)
|
|
|
|
klass = begin
|
2019-07-07 11:18:12 +05:30
|
|
|
class_name.constantize
|
2017-08-17 22:00:37 +05:30
|
|
|
rescue NameError
|
|
|
|
nil
|
|
|
|
end
|
|
|
|
return unless klass
|
|
|
|
|
2019-07-07 11:18:12 +05:30
|
|
|
klass
|
|
|
|
.reactive_cache_worker_finder
|
|
|
|
.call(id, *args)
|
|
|
|
.try(:exclusively_update_reactive_cache!, *args)
|
2020-03-13 15:44:24 +05:30
|
|
|
rescue ReactiveCaching::ExceededReactiveCacheLimit => e
|
|
|
|
Gitlab::ErrorTracking.track_exception(e)
|
2017-08-17 22:00:37 +05:30
|
|
|
end
|
|
|
|
end
|