Совместное использование соединений БД между объектами с использованием методов класса в ruby?
Я пишу сценарий ruby, который будет использоваться для делегирования политики доступа Postfix SMTP. Скрипт должен получить доступ к базе данных Tokyo Tyrant. Я использую EventMachine, чтобы заботиться о сетевых подключениях. EventMachine нужен класс EventMachine::Connection, который создается циклом обработки EventMachine при каждом создании нового соединения. поэтому для каждого соединения создается экземпляр класса и уничтожается.
Я создаю соединение с Tokyo Tyrant из post_init EventMachine::Connection (то есть сразу после установки соединения) и разрываю его после того, как соединение разорвано.
Мой вопрос, если это правильный способ подключения к БД? т.е. устанавливать связь каждый раз, когда мне это нужно, и разрывать ее после того, как я закончу? Не лучше ли подключиться к БД один раз (при запуске программы) и разорвать ее во время завершения работы программы? Если это так, как я должен кодировать это?
Мой код:
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 "*" }
}
с уважением,
Радж
1 ответ
Удивительно, что нет ответов на этот вопрос.
Что вам, вероятно, понадобится, это пул соединений, где вы можете извлекать, использовать и возвращать соединения по мере необходимости.
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