Как я могу получить и запустить сценарии ruby-сервера с Bluepill?

У меня есть два сценария сервера ruby, powerupserver.rb и outputserver.rb, в форме:

require '/Library/WebServer/sample_app/config/environment'
# more requires

@server = TCPServer.open(port_number)                          
loop do                                                 
  Thread.start(@server.accept) do |sock| 
    # do stuff
  end
end

В разработке я использую Foreman для их запуска, и это прекрасно работает. Сейчас я пытаюсь запускать и отслеживать их в фоновом режиме как демонов с Bluepill. Я выбрал Bluepill в основном потому, что у Foreman есть опция экспорта в файл конфигурации Bluepill (файл.pill). Поэтому я сделал это, а затем изменил файл.pill по мере необходимости, чтобы получить следующее:

Bluepill.application("sample_app", :foreground => false, :log_file => "/var/bluepill/log/bluepill.log") do |app|

  app.process("powerupserver") do |process|
    process.start_command = "ruby powerupserver.rb"
    process.working_dir = "/Library/WebServer/sample_app"
    process.pid_file = "/var/bluepill/pids/powerupserver-1.pid"
    process.daemonize = true
    process.stdout = process.stderr = "/var/bluepill/log/powerupserver-1.log"

    process.start_grace_time = 3.seconds
    process.stop_grace_time = 5.seconds
    process.restart_grace_time = 8.seconds
    process.stop_signals = [:quit, 30.seconds, :term, 5.seconds, :kill]

    process.checks :cpu_usage, :every => 10.seconds, :below => 5, :times => 3
    process.checks :mem_usage, :every => 10.seconds, :below => 100.megabytes, :times => [3,5]
    process.checks :flapping, :times => 2, :within => 30.seconds, :retry_in => 7.seconds

  end

  # more lines here mimicking above, but for server script 'outputserver.rb'
end

Когда я загружаю этот.pill и проверяю статус (статус sudo bluepill), я вижу:

$ sudo bluepill status
powerupserver(pid:0): up
outputserver(pid:0): up

Так что он предположительно работает (хотя и с pid = 0? Что, конечно, не очень хорошо), но я вижу, что они не работают / делают то, что должны делать. Может ли кто-нибудь со знанием Bluepill помочь мне понять, что я здесь делаю не так? Огромное спасибо заранее!

1 ответ

Решение

В итоге я использовал рубиновый гем Daemons для демонизации моих скриптов и Bluepill для их мониторинга. Я знаю, что вы можете сделать оба, используя только Bluepill, но я не мог понять это в то время, и моя система работала просто отлично. Я использую Rails 3.0.3, Daemons 1.1.5 и Bluepill 0.0.51. Итак, обо всем по порядку, убедитесь, что у вас установлены Daemons и Bluepill.

Допустим, у нас есть myserver.rb, скрипт сервера ruby, который находится в корне моего приложения rails. Чтобы демонизировать его с помощью демонов, создайте myserver_control.rb в корневой папке, чтобы сообщить демонам, как демонизировать:

# myserver_control.rb
require 'rubygems'
require 'daemons'

@options = {
    :dir_mode => :normal,
    :dir => '/Library/WebServer/myrailsapp/pids',
    :multiple => true,
    :backtrace => true,
    :monitor => false,
    :log_dir => '/Library/WebServer/myrailsapp/log',
    :log_output => true
}

Daemons.run('myserver.rb', @options)

Ознакомьтесь с документацией Daemon, чтобы узнать больше о хэше опций. Теперь вы можете запустить своего демона из корневой папки приложения rails в командной строке, используя команду sudo ruby ​​myserver_control.rb start. Это команда запуска демона, которую вы можете поместить в свой конфигурационный файл Bluepill (файл myrailsapp.pill) следующим образом:

Bluepill.application("myrailsapp", :foreground => false, :log_file => "/Library/WebServer/myrailsapp/log/bluepill.log") do |app|

  app.process("myserver") do |process|

    process.start_command = "sudo ruby myserver_control.rb start"
    process.stop_command = "sudo ruby myserver_control.rb stop"
    process.restart_command = "sudo ruby myserver_control.rb restart"

    process.pid_file = "/Library/WebServer/myrailsapp/pids/myserver.rb0.pid"

    process.working_dir = "/Library/WebServer/myrailsapp"

    process.start_grace_time = 5.seconds
    process.stop_grace_time = 5.seconds
    process.restart_grace_time = 8.seconds

  end
end

Обязательно прочтите документацию по Bluepill, чтобы увидеть все возможные варианты. Затем, когда вы запускаете Bluepill, у вас есть контролируемый демон. Убедитесь, что все папки, указанные в приведенных выше примерах, существуют (например, pids).

Другие вопросы по тегам