2020-05-28 02:40:37 -05:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2020-06-15 03:23:24 -05:00
|
|
|
if defined?(RailsFailover::Redis)
|
2020-06-15 02:56:57 -05:00
|
|
|
message_bus_keepalive_interval = nil
|
2020-06-07 23:32:14 -05:00
|
|
|
|
2020-06-15 02:56:57 -05:00
|
|
|
RailsFailover::Redis.on_failover do
|
|
|
|
message_bus_keepalive_interval = MessageBus.keepalive_interval
|
|
|
|
MessageBus.keepalive_interval = -1 # Disable MessageBus keepalive_interval
|
|
|
|
Discourse.received_redis_readonly!
|
|
|
|
end
|
2020-06-02 04:24:14 -05:00
|
|
|
|
2020-06-15 02:56:57 -05:00
|
|
|
RailsFailover::Redis.on_fallback do
|
|
|
|
Discourse.clear_redis_readonly!
|
|
|
|
Discourse.request_refresh!
|
|
|
|
MessageBus.keepalive_interval = message_bus_keepalive_interval
|
2020-09-17 22:17:54 -05:00
|
|
|
|
|
|
|
ObjectSpace.each_object(DistributedCache) do |cache|
|
|
|
|
cache.clear
|
|
|
|
end
|
2020-09-18 05:44:25 -05:00
|
|
|
|
|
|
|
SiteSetting.refresh!
|
2020-06-10 01:03:20 -05:00
|
|
|
end
|
2020-06-15 22:53:52 -05:00
|
|
|
|
|
|
|
if Rails.logger.respond_to? :chained
|
|
|
|
RailsFailover::Redis.logger = Rails.logger.chained.first
|
|
|
|
end
|
2020-06-11 00:45:46 -05:00
|
|
|
end
|
2020-06-10 01:03:20 -05:00
|
|
|
|
2020-06-15 03:23:24 -05:00
|
|
|
if defined?(RailsFailover::ActiveRecord)
|
2020-06-15 22:03:47 -05:00
|
|
|
return unless Rails.configuration.active_record_rails_failover
|
|
|
|
|
2020-06-15 02:56:57 -05:00
|
|
|
if Rails.configuration.multisite
|
|
|
|
if ActiveRecord::Base.current_role == ActiveRecord::Base.reading_role
|
|
|
|
RailsMultisite::ConnectionManagement.default_connection_handler =
|
|
|
|
ActiveRecord::Base.connection_handlers[ActiveRecord::Base.reading_role]
|
|
|
|
end
|
2020-05-28 02:40:37 -05:00
|
|
|
end
|
|
|
|
|
2020-06-15 02:56:57 -05:00
|
|
|
RailsFailover::ActiveRecord.on_failover do
|
2020-07-12 21:13:37 -05:00
|
|
|
if RailsMultisite::ConnectionManagement.current_db == RailsMultisite::ConnectionManagement::DEFAULT
|
2020-07-08 22:46:30 -05:00
|
|
|
RailsMultisite::ConnectionManagement.each_connection do
|
|
|
|
Sidekiq.pause!("pg_failover") if !Sidekiq.paused?
|
2020-07-21 00:51:37 -05:00
|
|
|
Discourse.enable_readonly_mode(Discourse::PG_READONLY_MODE_KEY)
|
2020-07-08 22:46:30 -05:00
|
|
|
end
|
2020-06-15 02:56:57 -05:00
|
|
|
end
|
2020-05-28 02:40:37 -05:00
|
|
|
end
|
|
|
|
|
2020-06-15 02:56:57 -05:00
|
|
|
RailsFailover::ActiveRecord.on_fallback do
|
|
|
|
RailsMultisite::ConnectionManagement.each_connection do
|
|
|
|
Discourse.disable_readonly_mode(Discourse::PG_READONLY_MODE_KEY)
|
|
|
|
Sidekiq.unpause! if Sidekiq.paused?
|
|
|
|
end
|
|
|
|
|
|
|
|
if Rails.configuration.multisite
|
|
|
|
RailsMultisite::ConnectionManagement.default_connection_handler =
|
|
|
|
ActiveRecord::Base.connection_handlers[ActiveRecord::Base.writing_role]
|
|
|
|
end
|
2020-05-31 22:23:58 -05:00
|
|
|
end
|
|
|
|
|
2020-06-15 02:56:57 -05:00
|
|
|
RailsFailover::ActiveRecord.register_force_reading_role_callback do
|
|
|
|
Discourse.redis.exists?(
|
|
|
|
Discourse::PG_READONLY_MODE_KEY,
|
|
|
|
Discourse::PG_FORCE_READONLY_MODE_KEY
|
|
|
|
)
|
|
|
|
rescue => e
|
2020-07-21 01:53:07 -05:00
|
|
|
if !e.is_a?(Redis::CannotConnectError)
|
2020-07-08 22:14:19 -05:00
|
|
|
Rails.logger.warn "#{e.class} #{e.message}: #{e.backtrace.join("\n")}"
|
2020-06-28 22:54:55 -05:00
|
|
|
end
|
2020-07-20 23:32:50 -05:00
|
|
|
|
|
|
|
false
|
2020-06-15 02:56:57 -05:00
|
|
|
end
|
2020-05-28 02:40:37 -05:00
|
|
|
end
|