From 54bdcd9b98b61e85070ab1b36b246449678028c2 Mon Sep 17 00:00:00 2001 From: Guo Xiang Tan Date: Tue, 8 Mar 2016 16:33:13 +0800 Subject: [PATCH] Update to new rate limit Redis config. --- Gemfile.lock | 2 +- config/initializers/100-logster.rb | 25 +++++++++++++------------ 2 files changed, 14 insertions(+), 13 deletions(-) diff --git a/Gemfile.lock b/Gemfile.lock index 1bfaa7ae128..79cd48ccc0e 100644 --- a/Gemfile.lock +++ b/Gemfile.lock @@ -150,7 +150,7 @@ GEM thor (~> 0.15) libv8 (3.16.14.13) listen (0.7.3) - logster (1.1.1) + logster (1.2.0) loofah (2.0.3) nokogiri (>= 1.5.9) lru_redux (1.1.0) diff --git a/config/initializers/100-logster.rb b/config/initializers/100-logster.rb index 8315587eafa..13904d283e8 100644 --- a/config/initializers/100-logster.rb +++ b/config/initializers/100-logster.rb @@ -57,21 +57,22 @@ Logster.config.subdirectory = "#{GlobalSetting.relative_url_root}/logs" Logster.config.application_version = Discourse.git_version +store = Logster.store redis = Logster.store.redis -Logster.config.redis_prefix = "#{redis.namespace}" -Logster.config.redis_raw_connection = redis.without_namespace +store.redis_prefix = Proc.new { redis.namespace } +store.redis_raw_connection = redis.without_namespace +severities = [Logger::WARN, Logger::ERROR, Logger::FATAL, Logger::UNKNOWN] -%w{minute hour}.each do |duration| - site_setting_error_rate = SiteSetting.public_send("alert_admins_if_errors_per_#{duration}") +RailsMultisite::ConnectionManagement.each_connection do + if error_rate_per_minute = SiteSetting.alert_admins_if_errors_per_minute > 0 + store.register_rate_limit_per_minute(severities, error_rate_per_minute) do |rate| + MessageBus.publish("/logs_error_rate_exceeded", { rate: rate, duration: 'minute' }) + end + end - if site_setting_error_rate > 0 - Logster.store.public_send( - "register_rate_limit_per_#{duration}", - [Logger::WARN, Logger::ERROR, Logger::FATAL, Logger::UNKNOWN], - site_setting_error_rate - ) do |rate| - - MessageBus.publish("/logs_error_rate_exceeded", { rate: rate, duration: duration }) + if error_rate_per_hour = SiteSetting.alert_admins_if_errors_per_hour > 0 + store.register_rate_limit_per_hour(severities, error_rate_per_hour) do |rate| + MessageBus.publish("/logs_error_rate_exceeded", { rate: rate, duration: 'hour' }) end end end