Как я могу использовать EventMachine.connect_unix_domain
во время работы Thin в качестве службы (используя скрипт инициализации (отрывок) и приведенную ниже конфигурацию).Код, приведенный ниже, является проблемой (я получаю ошибку eventmachine not initialized: evma_connect_to_unix_server
).Второй пример кода работает, но не позволяет мне демонизировать thin (я не думаю).Разве у Thin еще нет запущенного экземпляра EventMachine?
ОБНОВЛЕНИЕ: как ни странно: остановка сервера (с service thin stop
), похоже, попадает в файл config.ru и запускает приложение (чтобы оно работало,пока команда stop
не истечет время и не убьет процесс).Что происходит, когда тонкие остановки могут вызывать такое поведение?
Код проблемы
class Server < Sinatra::Base
# Webserver code removed
end
module Handler
def receive_data data
$received_data_changed = 1
$received_data = data
end
end
$sock = EventMachine.connect_unix_domain("/tmp/mysock.sock", Handler)
Рабочий код
EventMachine.run do
class Server < Sinatra::Base
# Webserver code removed
end
module Handler
def receive_data data
$received_data_changed = 1
$received_data = data
end
end
$sock = EventMachine.connect_unix_domain("/tmp/mysock.sock", Handler)
Server.run!(:port => 4567)
end
Выдержка сценария инициализации
DAEMON=/usr/local/bin/thin
SCRIPT_NAME=/etc/init.d/thin
CONFIG_PATH=/etc/thin
# Exit if the package is not installed
[ -x "$DAEMON" ] || exit 0
case "$1" in
start)
$DAEMON start --all $CONFIG_PATH
;;
Тонкий Конфиг
---
chdir: /var/www
environment: development
timeout: 30
log: log/thin.log
pid: tmp/pids/thin.pid
max_conns: 1024
max_persistent_conns: 512
require: []
wait: 30
servers: 1
socket: /tmp/thin.server.sock
daemonize: true