【问题标题】:Rate-limiting for rails controllersRails 控制器的速率限制
【发布时间】:2012-12-21 04:46:06
【问题描述】:

我正在为我的 rails 3 应用程序搜索限速引擎。我找到了一些,但这不是我需要的。我找到了 rack-throttle gem 和 curbitt gem。似乎 rack-throttle 对 Rails 应用程序的每个请求都有效,但我需要将请求限制为一个操作。 Curbit 最近一次更新是在两年前。谁能告诉我我可以使用的任何其他限速引擎?请注意,它应该与缓存一起使用。

【问题讨论】:

  • 网络服务器(apache?)上的限制怎么样
  • @Rogier 项目将部署在heroku上

标签: ruby-on-rails gem rate-limiting


【解决方案1】:

好吧,最后机架油门是一个很好的解决方案。

您可以通过以下方式进行操作。您需要定义自定义限制器。它可以基于以下任一限制器

Rack::Throttle::Limiter
Rack::Throttle::Interval
Rack::Throttle::Hourly
Rack::Throttle::Daily

您需要做的就是从上述类之一派生来定义自定义逻辑。例如:

class CustomLimiter < Rack::Throttle::Interval
  def allowed?(request)
  #custom logic here
  end
end

您应该将此文件放在RAILS_ROOT/lib 路径中。然后在application.rb 文件中,您应该指定要用作限制器的类。例如,如果您只想将限制器应用于一个操作,您可以通过以下方式进行:

#lib/custom_limiter.rb
class CustomLimiter < Rack::Throttle::Interval
  def allowed?(request)
    path_info = Rails.application.routes.recognize_path request.url rescue {}
    if path_info[:controller] == "application" and path_info[:action] == "check_answer"
      super
    else 
      true
    end
  end
end

#config/application.rb
class Application < Rails::Application
  ... 
  #Set up rate limiting
  config.require "custom_limiter"
  config.middleware.use CustomLimiter, :min => 0.2
  ...
end

您可能需要考虑this

希望对你有用

UPD:

您可能想查看另一个解决方案:rack-attack

【讨论】:

  • 代码错误!更改为 config.require "custom_failure"
  • 已修复。现在一切似乎都很好
  • 感谢您的逐步指导。只是想了解更多有关设置的信息。您使用什么样的数据库来存储计数器?
  • 还要查看白名单吗?并列入黑名单?方法。 github.com/datagraph/rack-throttle/blob/master/lib/rack/…
  • 也被抓住了。如果您想对 GET 请求以外的任何内容进行速率限制,请确保您还将 request.request_method 作为第二个参数传递给识别路径(例如:recognize_path(request.url, request.request_method))。
【解决方案2】:

rack-throttle 做你想做的事。继承Limiter 并定义您自己的#allowed? 方法。如果请求不是您想要限制的操作并且不计入限制,则只需返回 true。看看daily.rb。重新定义#cache_set,这样它就不会保存那些与您要限制的路线不匹配的路线。

【讨论】:

  • 我已经覆盖了它,并将文件放在lib目录中并重新启动服务器,但它不起作用。 class CustomLimiter &lt; Rack::Throttle::Limiter def allowed?(request) true == true end end 页面已打开,但资产未加载,我得到 ERROR NoMethodError: undefined method each' for "403 Forbidden (Rate Limit Exceeded)` 所以没有应用样式。在application.rb 我有config.middleware.use Rack::Throttle::Interval, :min =&gt; 0.2。怎么了?
猜你喜欢
  • 2011-09-23
  • 2014-02-10
  • 1970-01-01
  • 2021-05-16
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2017-10-13
相关资源
最近更新 更多