加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

ruby-on-rails – 如何在使用Rack Cache时跟踪API请求的数量

发布时间:2020-12-17 03:05:54 所属栏目:百科 来源:网络整理
导读:我将使用Rack Cache(带Memcache)来缓存我正在使用Rails构建的API的响应.另外,我需要为API实现命中计数.有什么建议可以解决这个问题吗?我猜它需要用Rack处理,但我不知道从哪里开始.谢谢! 解决方法 我建议将一个Rack中间件添加到中间件堆栈的顶部,这会增加请
我将使用Rack Cache(带Memcache)来缓存我正在使用Rails构建的API的响应.另外,我需要为API实现命中计数.有什么建议可以解决这个问题吗?我猜它需要用Rack处理,但我不知道从哪里开始.谢谢!

解决方法

我建议将一个Rack中间件添加到中间件堆栈的顶部,这会增加请求路径的计数器.

例如,要使用Redis执行此操作:

# lib/request_counter.rb
class RequestCounter
  def self.redis
    @redis ||= Redis.new(host: ENV["REDIS_HOST"],port: ENV["REDIS_PORT"])
  end

  def initialize(app)
    @app = app
  end

  def call(env)
    request = Rack::Request.new(env)
    self.class.redis.incr "request_counter:#{request.fullpath}"
    @app.call(env)
  end
end

# config/application.rb (in the Rails::Application subclass)
require "request_counter"
config.middleware.insert(0,RequestCounter)

这意味着对/ path的每个请求都会增加Redis密钥request_counter:/ path

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读