diff options
Diffstat (limited to 'lib/tasks/gitlab/db/lock_writes.rake')
-rw-r--r-- | lib/tasks/gitlab/db/lock_writes.rake | 51 |
1 files changed, 12 insertions, 39 deletions
diff --git a/lib/tasks/gitlab/db/lock_writes.rake b/lib/tasks/gitlab/db/lock_writes.rake index 212d60a7231..59478d47d12 100644 --- a/lib/tasks/gitlab/db/lock_writes.rake +++ b/lib/tasks/gitlab/db/lock_writes.rake @@ -4,49 +4,22 @@ namespace :gitlab do namespace :db do desc "GitLab | DB | Install prevent write triggers on all databases" task lock_writes: [:environment, 'gitlab:db:validate_config'] do - Gitlab::Database::EachDatabase.each_database_connection(include_shared: false) do |connection, database_name| - schemas_for_connection = Gitlab::Database.gitlab_schemas_for_connection(connection) - - Gitlab::Database::LockWritesManager.tables_to_lock(connection) do |table_name, schema_name| - # TODO: https://gitlab.com/gitlab-org/gitlab/-/issues/366834 - next if schema_name == :gitlab_geo - - lock_writes_manager = Gitlab::Database::LockWritesManager.new( - table_name: table_name, - connection: connection, - database_name: database_name, - with_retries: true, - logger: Logger.new($stdout), - dry_run: ENV['DRY_RUN'] == 'true' - ) - - if schemas_for_connection.include?(schema_name.to_sym) - lock_writes_manager.unlock_writes - else - lock_writes_manager.lock_writes - end - end - end + logger = Logger.new($stdout) + logger.level = Gitlab::Utils.to_boolean(ENV['VERBOSE']) ? Logger::INFO : Logger::WARN + Gitlab::Database::TablesLocker.new( + logger: logger, + dry_run: Gitlab::Utils.to_boolean(ENV['DRY_RUN'], default: false) + ).lock_writes end desc "GitLab | DB | Remove all triggers that prevents writes from all databases" task unlock_writes: :environment do - Gitlab::Database::EachDatabase.each_database_connection do |connection, database_name| - Gitlab::Database::LockWritesManager.tables_to_lock(connection) do |table_name, schema_name| - # TODO: https://gitlab.com/gitlab-org/gitlab/-/issues/366834 - next if schema_name == :gitlab_geo - - lock_writes_manager = Gitlab::Database::LockWritesManager.new( - table_name: table_name, - connection: connection, - database_name: database_name, - with_retries: true, - logger: Logger.new($stdout) - ) - - lock_writes_manager.unlock_writes - end - end + logger = Logger.new($stdout) + logger.level = Gitlab::Utils.to_boolean(ENV['VERBOSE']) ? Logger::INFO : Logger::WARN + Gitlab::Database::TablesLocker.new( + logger: logger, + dry_run: Gitlab::Utils.to_boolean(ENV['DRY_RUN'], default: false) + ).unlock_writes end end end |