Merge branch 'post-migrate-private-profile' into 'master'

Migrate remaining users with null private_profile

See merge request gitlab-org/gitlab-ce!31708
This commit is contained in:
Mayra Cabrera 2019-08-14 20:26:23 +00:00
commit b3aa0711f0
3 changed files with 37 additions and 1 deletions

View File

@ -0,0 +1,5 @@
---
title: Migrate remaining users with null private_profile
merge_request: 31708
author:
type: other

View File

@ -0,0 +1,31 @@
# frozen_string_literal: true
class MigratePrivateProfileNulls < ActiveRecord::Migration[5.2]
include Gitlab::Database::MigrationHelpers
DOWNTIME = false
DELAY = 5.minutes.to_i
BATCH_SIZE = 1_000
disable_ddl_transaction!
class User < ActiveRecord::Base
self.table_name = 'users'
include ::EachBatch
end
def up
# Migration will take about 7 hours
User.where(private_profile: nil).each_batch(of: BATCH_SIZE) do |batch, index|
range = batch.pluck(Arel.sql("MIN(id)"), Arel.sql("MAX(id)")).first
delay = index * DELAY
BackgroundMigrationWorker.perform_in(delay.seconds, 'MigrateNullPrivateProfileToFalse', [*range])
end
end
def down
# noop
end
end

View File

@ -10,7 +10,7 @@
#
# It's strongly recommended that you check this file into your version control system.
ActiveRecord::Schema.define(version: 2019_08_06_071559) do
ActiveRecord::Schema.define(version: 2019_08_12_070645) do
# These are extensions that must be enabled in order to support this database
enable_extension "pg_trgm"