debian-mirror-gitlab/app/workers/dependency_proxy/image_ttl_group_policy_worker.rb

50 lines
2 KiB
Ruby
Raw Normal View History

2021-11-18 22:05:49 +05:30
# frozen_string_literal: true
module DependencyProxy
class ImageTtlGroupPolicyWorker # rubocop:disable Scalability/IdempotentWorker
include ApplicationWorker
include CronjobQueue # rubocop:disable Scalability/CronWorkerContext
2022-01-12 12:59:36 +05:30
include DependencyProxy::Expireable
2021-11-18 22:05:49 +05:30
data_consistency :always
feature_category :dependency_proxy
def perform
DependencyProxy::ImageTtlGroupPolicy.enabled.each do |policy|
2021-12-11 22:18:48 +05:30
qualified_blobs = policy.group.dependency_proxy_blobs.active.read_before(policy.ttl)
qualified_manifests = policy.group.dependency_proxy_manifests.active.read_before(policy.ttl)
2021-11-18 22:05:49 +05:30
2022-01-12 12:59:36 +05:30
expire_artifacts(qualified_blobs)
expire_artifacts(qualified_manifests)
2021-11-18 22:05:49 +05:30
end
log_counts
end
private
def log_counts
use_replica_if_available do
2022-03-02 08:16:31 +05:30
expired_blob_count = DependencyProxy::Blob.pending_destruction.count
expired_manifest_count = DependencyProxy::Manifest.pending_destruction.count
2021-11-18 22:05:49 +05:30
processing_blob_count = DependencyProxy::Blob.processing.count
processing_manifest_count = DependencyProxy::Manifest.processing.count
error_blob_count = DependencyProxy::Blob.error.count
error_manifest_count = DependencyProxy::Manifest.error.count
log_extra_metadata_on_done(:expired_dependency_proxy_blob_count, expired_blob_count)
log_extra_metadata_on_done(:expired_dependency_proxy_manifest_count, expired_manifest_count)
log_extra_metadata_on_done(:processing_dependency_proxy_blob_count, processing_blob_count)
log_extra_metadata_on_done(:processing_dependency_proxy_manifest_count, processing_manifest_count)
log_extra_metadata_on_done(:error_dependency_proxy_blob_count, error_blob_count)
log_extra_metadata_on_done(:error_dependency_proxy_manifest_count, error_manifest_count)
end
end
def use_replica_if_available(&block)
::Gitlab::Database::LoadBalancing::Session.current.use_replicas_for_read_queries(&block)
end
end
end