2018-10-20 18:00:19 +00:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
|
|
|
# Don't handle sidekiq configuration as it
|
|
|
|
# has its own special active record configuration here
|
2019-12-22 09:07:51 +00:00
|
|
|
if defined?(ActiveRecord::Base) && !Gitlab::Runtime.sidekiq?
|
2018-10-20 18:00:19 +00:00
|
|
|
Gitlab::Cluster::LifecycleEvents.on_worker_start do
|
|
|
|
ActiveSupport.on_load(:active_record) do
|
|
|
|
ActiveRecord::Base.establish_connection
|
|
|
|
|
2019-07-10 19:26:47 +00:00
|
|
|
Rails.logger.debug("ActiveRecord connection established") # rubocop:disable Gitlab/RailsLogger
|
2018-10-20 18:00:19 +00:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
if defined?(ActiveRecord::Base)
|
|
|
|
Gitlab::Cluster::LifecycleEvents.on_before_fork do
|
2020-02-20 18:08:51 +00:00
|
|
|
raise 'ActiveRecord connection not established. Unable to start.' unless Gitlab::Database.exists?
|
|
|
|
|
2018-10-20 18:00:19 +00:00
|
|
|
# the following is highly recommended for Rails + "preload_app true"
|
|
|
|
# as there's no need for the master process to hold a connection
|
|
|
|
ActiveRecord::Base.connection.disconnect!
|
|
|
|
|
2019-07-10 19:26:47 +00:00
|
|
|
Rails.logger.debug("ActiveRecord connection disconnected") # rubocop:disable Gitlab/RailsLogger
|
2018-10-20 18:00:19 +00:00
|
|
|
end
|
|
|
|
end
|