60 秒ごとに実行し、bluepill で起動/停止して監視するカスタム デーモンを作成しようとしています。
誰かがこれをより簡単に行う方法を教えてもらえますか、それとも私が間違っていることを教えてください。
現在、bluepill は実行するようにデーモンを開始していますが、停止と開始を繰り返しているため、その実行を認識していないようです。
これが私の.pillファイルからの私のコードです
app.process("get_dropboxes") do |process|
process.working_dir = RAILS_ROOT
process.pid_file = File.join(RAILS_ROOT, "tmp", "pids", "get_dropbox.pid")
process.start_command = "/usr/bin/env RAILS_ENV=#{RAILS_ENV} bundle exec lib/daemons/get_dropbox_ctl start"
process.stop_command = "/usr/bin/env RAILS_ENV=#{RAILS_ENV} bundle exec lib/daemons/get_dropbox_ctl stop"
process.start_grace_time = 10.seconds
process.stop_grace_time = 10.seconds
process.restart_grace_time = 10.seconds
process.checks :cpu_usage, :every => 30.seconds, :below => 20, :times => [3,5]
process.checks :mem_usage, :every => 30.seconds, :below => 350.megabytes, :times => [3,5]
end
これが私のget_dropbox_ctlファイルです
#!/usr/bin/env ruby
require 'rubygems'
require "daemons"
require 'yaml'
require 'erb'
gem 'activesupport', '>=3.0.0'
require 'active_support'
# For some reason, ActiveSupport 3.0.0 doesn't load.
# Load needed extension directly for now.
require "active_support/core_ext/object"
require "active_support/core_ext/hash"
options = YAML.load(
ERB.new(
IO.read(
File.dirname(__FILE__) + "/../../config/daemons.yml"
)).result).with_indifferent_access
options[:dir_mode] = options[:dir_mode].to_sym
Daemons.run File.dirname(__FILE__) + "/get_dropbox.rb", options
そして、これが私のget_dropbox.rbファイルです
#!/usr/bin/env ruby
# You might want to change this
ENV["RAILS_ENV"] ||= "production"
require 'net/pop'
require File.dirname(__FILE__) + "/../../config/application"
Rails.application.require_environment!
$running = true
Signal.trap("TERM") do
$running = false
end
while($running) do
# do stuff .......
sleep 60
end
取得したログ
[2011-07-13T16:55:00.464202 #32257] WARN -- : [domain.com:get_dropboxes] pid_file /var/www/domain.com/current/tmp/pids/get_dropbox.pid does not exist or cannot be read
W, [2011-07-13T16:55:00.464315 #32257] WARN -- : [domain.com:get_dropboxes] pid_file /var/www/domain.com/current/tmp/pids/get_dropbox.pid does not exist or cannot be read
W, [2011-07-13T16:55:00.464505 #32257] WARN -- : [domain.com:get_dropboxes] Executing start command: /usr/bin/env RAILS_ENV=production bundle exec lib/daemons/get_dropbox_ctl start
I, [2011-07-13T16:55:01.602210 #32257] INFO -- : [domain.com:get_dropboxes] Going from down => starting
確かにこれより簡単な方法はありますか?