Update to new rate limit Redis config.

This commit is contained in:
Guo Xiang Tan 2016-03-08 16:33:13 +08:00
parent 67a5fc39de
commit 54bdcd9b98
2 changed files with 14 additions and 13 deletions

View File

@ -150,7 +150,7 @@ GEM
thor (~> 0.15) thor (~> 0.15)
libv8 (3.16.14.13) libv8 (3.16.14.13)
listen (0.7.3) listen (0.7.3)
logster (1.1.1) logster (1.2.0)
loofah (2.0.3) loofah (2.0.3)
nokogiri (>= 1.5.9) nokogiri (>= 1.5.9)
lru_redux (1.1.0) lru_redux (1.1.0)

View File

@ -57,21 +57,22 @@ Logster.config.subdirectory = "#{GlobalSetting.relative_url_root}/logs"
Logster.config.application_version = Discourse.git_version Logster.config.application_version = Discourse.git_version
store = Logster.store
redis = Logster.store.redis redis = Logster.store.redis
Logster.config.redis_prefix = "#{redis.namespace}" store.redis_prefix = Proc.new { redis.namespace }
Logster.config.redis_raw_connection = redis.without_namespace store.redis_raw_connection = redis.without_namespace
severities = [Logger::WARN, Logger::ERROR, Logger::FATAL, Logger::UNKNOWN]
%w{minute hour}.each do |duration| RailsMultisite::ConnectionManagement.each_connection do
site_setting_error_rate = SiteSetting.public_send("alert_admins_if_errors_per_#{duration}") 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 if error_rate_per_hour = SiteSetting.alert_admins_if_errors_per_hour > 0
Logster.store.public_send( store.register_rate_limit_per_hour(severities, error_rate_per_hour) do |rate|
"register_rate_limit_per_#{duration}", MessageBus.publish("/logs_error_rate_exceeded", { rate: rate, duration: 'hour' })
[Logger::WARN, Logger::ERROR, Logger::FATAL, Logger::UNKNOWN],
site_setting_error_rate
) do |rate|
MessageBus.publish("/logs_error_rate_exceeded", { rate: rate, duration: duration })
end end
end end
end end