[英]How to reduce Redis connections in a Ruby/Sinatra app? Use connection_pool?
我有一个可以正常工作的Sinatra应用程序,该应用程序使用redis-namespace进行Redis连接。 它运行正常,但在Heroku上,尽管流量很少,但仍然用尽了10个Redis连接-它们似乎保持打开状态很久,并且该应用程序还在不断打开新的连接。
因此,可能会有更好的方法来构造我所拥有的内容,因此它不会一直打开新的连接。 或者也许我可以使用connection_pool ...,尽管我不确定如何将它与 redis-namespace一起使用。
Sinatra前端( myapp/frontend.rb
)类似于:
require 'sinatra/base'
require 'myapp/store'
module MyApp
class Frontend < Sinatra::Base
registration_store = MyApp::Store::Registration.new
subscription_store = MyApp::Store::Subscription.new
get '/' do
...
end
...
end
end
访问Redis的Store类位于myapp/store.rb
:
require 'redis'
require 'redis-namespace'
module MyApp
module Store
class RedisBase
attr_accessor :redis
def initialize
uri = URI.parse(ENV['REDISCLOUD_URL'])
redis = ::Redis.new(:host => uri.host, :port => uri.port, :password => uri.password)
@redis = ::Redis::Namespace.new(:myapp, :redis => redis)
end
class Registration < RedisBase
def add(user_id)
redis.sadd(:registrations, user_id)
end
...
end
class Subscription < RedisBase
...
end
end
end
end
前端通过Store类存储数据: registration_store.add(37)
。
我做错了什么事,导致不必要地打开新连接? 或者,如何添加connection_pool或类似的内容?
我碰到一个类似的问题,偶然发现了这个问题。 我认为您应该在代码中的某处添加redis.quit
。 通过在redis命令行上使用client list
进行一些手动测试监视连接,可以使连接在退出时消失。 该对象以后仍可以使用,并且在关闭连接后将打开一个新连接。 无需池! (至少当负载较低时...。我想您可能最终会因呼叫在较高负载下无法建立连接而告终。)
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.