共享DB连接跨目的使用类方法在红宝石?
-
12-09-2019 - |
题
我写的红宝石脚本是用作后缀SMTP访问策略的代表团。脚本需要访问东京的暴君的数据库。我用用eventmachine照顾网络连接。用eventmachine需要用eventmachine::连接类实例用eventmachine的处理循环,每当一个新的连接创建。因此,对于每一个接一个流化和毁坏。
我创建一个连接东京的暴君从post_init的用eventmachine::连接(即权利之后的连接安装)和撕下它,连接后被终止。
我的问题是如果这是适当的的方式连接的数据库?即使连接的每一个yime我需要它撕下来之后我说完了吗?不会更好地连接的数据库一旦(当程序启动)拆除它在程序的关机?如果是这样我应该怎么代码吗?
我的代码是:
require 'rubygems'
require 'eventmachine'
require 'rufus/tokyo/tyrant'
class LineCounter < EM::Connection
ActionAllow = "action=dunno\n\n"
def post_init
puts "Received a new connection"
@tokyo = Rufus::Tokyo::Tyrant.new('server', 1978)
@data_received = ""
end
def receive_data data
@data_received << data
@data_received.lines do |line|
key = line.split('=')[0]
value = line.split('=')[1]
@reverse_client_name = value.strip() if key == 'reverse_client_name'
@client_address = value.strip() if key == 'client_address'
@tokyo[@client_address] = @reverse_client_name
end
puts @client_address, @reverse_client_name
send_data ActionAllow
end
def unbind
@tokyo.close
end
end
EventMachine::run {
host,port = "127.0.0.1", 9997
EventMachine::start_server host, port, LineCounter
puts "Now accepting connections on address #{host}, port #{port}..."
EventMachine::add_periodic_timer( 10 ) { $stderr.write "*" }
}
与的问候,
raj
解决方案
令人惊讶的是没有回答这个问题。
什么你可能需要的是一个连接池在这里你可以获取、使用和返回的连接,作为它们是必需的。
class ConnectionPool
def initialize(&block)
@pool = [ ]
@generator = block
end
def fetch
@pool.shift or @generator and @generator.call
end
def release(handle)
@pool.push(handle)
end
def use
if (block_given?)
handle = fetch
yield(handle)
release(handle)
end
end
end
# Declare a pool with an appropriate connection generator
tokyo_pool = ConnectionPool.new do
Rufus::Tokyo::Tyrant.new('server', 1978)
end
# Fetch/Release cycle
tokyo = tokyo_pool.fetch
tokyo[@client_address] = @reverse_client_name
tokyo_pool.release(tokyo)
# Simple block-method for use
tokyo_pool.use do |tokyo|
tokyo[@client_address] = @reverse_client_name
end
不隶属于 StackOverflow