diff options
author | Mayra Cabrera <mcabrera@gitlab.com> | 2019-09-04 20:10:55 +0000 |
---|---|---|
committer | Mayra Cabrera <mcabrera@gitlab.com> | 2019-09-04 20:10:55 +0000 |
commit | 1961fd1f06d8028a971fed4adea38180999d70e9 (patch) | |
tree | c8c6318ff62bff193822f00fe4176e12717dddf5 | |
parent | c5ecf10642cc212026f82cba465ba91a992d8de0 (diff) | |
parent | bd56acd37814933e5fb51f1fe1adce6171532979 (diff) | |
download | gitlab-ce-1961fd1f06d8028a971fed4adea38180999d70e9.tar.gz |
Merge branch 'ab-add-index-for-ci-builds-metrics' into 'master'
Create partial index for gitlab-monitor CI metrics
See merge request gitlab-org/gitlab-ce!32546
-rw-r--r-- | changelogs/unreleased/ab-add-index-for-ci-builds-metrics.yml | 5 | ||||
-rw-r--r-- | db/migrate/20190902152329_add_index_for_ci_builds_metrics.rb | 19 | ||||
-rw-r--r-- | db/schema.rb | 1 |
3 files changed, 25 insertions, 0 deletions
diff --git a/changelogs/unreleased/ab-add-index-for-ci-builds-metrics.yml b/changelogs/unreleased/ab-add-index-for-ci-builds-metrics.yml new file mode 100644 index 00000000000..03a37dc0c04 --- /dev/null +++ b/changelogs/unreleased/ab-add-index-for-ci-builds-metrics.yml @@ -0,0 +1,5 @@ +--- +title: Create partial index for gitlab-monitor CI metrics +merge_request: 32546 +author: +type: performance diff --git a/db/migrate/20190902152329_add_index_for_ci_builds_metrics.rb b/db/migrate/20190902152329_add_index_for_ci_builds_metrics.rb new file mode 100644 index 00000000000..b755d60e311 --- /dev/null +++ b/db/migrate/20190902152329_add_index_for_ci_builds_metrics.rb @@ -0,0 +1,19 @@ +# frozen_string_literal: true + +class AddIndexForCiBuildsMetrics < ActiveRecord::Migration[5.2] + include Gitlab::Database::MigrationHelpers + + DOWNTIME = false + + disable_ddl_transaction! + + INDEX_NAME = 'ci_builds_gitlab_monitor_metrics' + + def up + add_concurrent_index(:ci_builds, [:status, :created_at, :project_id], where: "type = 'Ci::Build'", name: INDEX_NAME) + end + + def down + remove_concurrent_index_by_name(:ci_builds, INDEX_NAME) + end +end diff --git a/db/schema.rb b/db/schema.rb index f2d6f70217b..79f4551ee26 100644 --- a/db/schema.rb +++ b/db/schema.rb @@ -605,6 +605,7 @@ ActiveRecord::Schema.define(version: 2019_09_02_160015) do t.index ["scheduled_at"], name: "partial_index_ci_builds_on_scheduled_at_with_scheduled_jobs", where: "((scheduled_at IS NOT NULL) AND ((type)::text = 'Ci::Build'::text) AND ((status)::text = 'scheduled'::text))" t.index ["stage_id", "stage_idx"], name: "tmp_build_stage_position_index", where: "(stage_idx IS NOT NULL)" t.index ["stage_id"], name: "index_ci_builds_on_stage_id" + t.index ["status", "created_at", "project_id"], name: "ci_builds_gitlab_monitor_metrics", where: "((type)::text = 'Ci::Build'::text)" t.index ["status", "type", "runner_id"], name: "index_ci_builds_on_status_and_type_and_runner_id" t.index ["token"], name: "index_ci_builds_on_token", unique: true t.index ["token_encrypted"], name: "index_ci_builds_on_token_encrypted", unique: true, where: "(token_encrypted IS NOT NULL)" |