ruby-on-rails – Rails是否能够优雅地处理缓存存储中断(memcach
发布时间:2020-12-17 03:41:39 所属栏目:百科 来源:网络整理
导读:我有兴趣使用 https://github.com/kickstarter/rack-attack扼杀滥用者和蛮力攻击者.我的应用程序运行在多个dynos上,所以我想Rails默认的FileStore并不完全有效,因为每个dyno都有一个文件系统,而且限制需要是两者的聚合. 如果我要为Rails.cache使用memcached
我有兴趣使用
https://github.com/kickstarter/rack-attack扼杀滥用者和蛮力攻击者.我的应用程序运行在多个dynos上,所以我想Rails默认的FileStore并不完全有效,因为每个dyno都有一个文件系统,而且限制需要是两者的聚合.
如果我要为Rails.cache使用memcached插件服务,如果memcached服务关闭(例如,对FileStore),Rails中是否有“回退”? 如果没有,随着memcached服务的中断,rails应用程序将崩溃或用户无法访问(与优雅地处理错误相比)? 解决方法
我是机架攻击的作者.
tl; dr:当你的缓存后端(memcached或redis)关闭时,所有请求都被允许(即失败打开). 这实际上取决于Rails缓存的功能. Dalli memcached客户端(ActiveSupport::Cache::DalliStore)和Redis客户端(ActiveSupport::Cache::RedisStore)都挽救连接错误和超时返回nil. 当机架攻击在缓存存储中查询限制值时,缓存存储返回nil.机架攻击强制转移到to_i以获得0.并且因为你的节流限制是> 0,允许请求. 机架攻击has integration tests在每次提交测试时运行,不会引发错误,并且当memcached / redis不可用时允许请求. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |