Commit 4a3dbc31 authored by Stan Hu's avatar Stan Hu

Merge branch 'stuck-ci-jobs-worker-optimize-running' into 'master'

Optimize StuckCiJobsWorker running builds query

See merge request gitlab-org/gitlab!68891
parents a1f037cc 5bb7b196
...@@ -58,8 +58,8 @@ class CommitStatus < Ci::ApplicationRecord ...@@ -58,8 +58,8 @@ class CommitStatus < Ci::ApplicationRecord
scope :in_pipelines, ->(pipelines) { where(pipeline: pipelines) } scope :in_pipelines, ->(pipelines) { where(pipeline: pipelines) }
scope :eager_load_pipeline, -> { eager_load(:pipeline, project: { namespace: :route }) } scope :eager_load_pipeline, -> { eager_load(:pipeline, project: { namespace: :route }) }
scope :with_pipeline, -> { joins(:pipeline) } scope :with_pipeline, -> { joins(:pipeline) }
scope :updated_at_before, ->(date) { where('ci_builds.updated_at < ?', date) }
scope :created_at_before, ->(date) { where('ci_builds.created_at < ?', date) } scope :created_at_before, ->(date) { where('ci_builds.created_at < ?', date) }
scope :updated_at_before, ->(date) { where('ci_builds.updated_at < ?', date) }
scope :updated_before, ->(lookback:, timeout:) { scope :updated_before, ->(lookback:, timeout:) {
where('(ci_builds.created_at BETWEEN ? AND ?) AND (ci_builds.updated_at BETWEEN ? AND ?)', lookback, timeout, lookback, timeout) where('(ci_builds.created_at BETWEEN ? AND ?) AND (ci_builds.updated_at BETWEEN ? AND ?)', lookback, timeout, lookback, timeout)
} }
......
...@@ -63,10 +63,12 @@ class StuckCiJobsWorker # rubocop:disable Scalability/IdempotentWorker ...@@ -63,10 +63,12 @@ class StuckCiJobsWorker # rubocop:disable Scalability/IdempotentWorker
end end
def running_timed_out_builds def running_timed_out_builds
Ci::Build.running.where( # rubocop: disable CodeReuse/ActiveRecord if Feature.enabled?(:ci_new_query_for_running_stuck_jobs)
'ci_builds.updated_at < ?', running_builds = Ci::Build.running.created_at_before(BUILD_RUNNING_OUTDATED_TIMEOUT.ago).order(created_at: :asc, project_id: :asc) # rubocop: disable CodeReuse/ActiveRecord
BUILD_RUNNING_OUTDATED_TIMEOUT.ago Ci::Build.id_in(running_builds).updated_at_before(BUILD_RUNNING_OUTDATED_TIMEOUT.ago)
) else
Ci::Build.running.updated_at_before(BUILD_RUNNING_OUTDATED_TIMEOUT.ago)
end
end end
def try_obtain_lease def try_obtain_lease
......
---
name: ci_new_query_for_running_stuck_jobs
introduced_by_url: https://gitlab.com/gitlab-org/gitlab/-/merge_requests/68891
rollout_issue_url: https://gitlab.com/gitlab-org/gitlab/-/issues/339264
milestone: '14.3'
type: development
group: group::pipeline execution
default_enabled: false
...@@ -186,6 +186,7 @@ RSpec.describe StuckCiJobsWorker do ...@@ -186,6 +186,7 @@ RSpec.describe StuckCiJobsWorker do
end end
end end
shared_examples 'job is running' do
context 'when job is running' do context 'when job is running' do
let(:status) { 'running' } let(:status) { 'running' }
...@@ -201,6 +202,17 @@ RSpec.describe StuckCiJobsWorker do ...@@ -201,6 +202,17 @@ RSpec.describe StuckCiJobsWorker do
it_behaves_like 'job is unchanged' it_behaves_like 'job is unchanged'
end end
end end
end
it_behaves_like 'job is running'
context 'when ci_new_query_for_running_stuck_jobs feature flag is disabled' do
before do
stub_feature_flags(ci_new_query_for_running_stuck_jobs: false)
end
it_behaves_like 'job is running'
end
%w(success skipped failed canceled).each do |status| %w(success skipped failed canceled).each do |status|
context "when job is #{status}" do context "when job is #{status}" do
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment