首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如果我使用w.keepalive但不使用$god sidekiq start,上帝宝石会启动一个手表

如果我使用w.keepalive但不使用$god sidekiq start,上帝宝石会启动一个手表
EN

Stack Overflow用户
提问于 2013-01-23 01:52:11
回答 1查看 806关注 0票数 3

我正在为在God Gem中使用Sidekiq而苦苦挣扎。我希望能够手动启动sidekiq进程,使用$god start sidekiq,但是这无法启动进程。如果我设置了w.keepalive (在下面的代码中注释掉了),我只能让它启动sidekiq进程。

我使用:$ god -c "./config.god" -D --log-level info启动上帝,在前台启动上帝,得到以下输出:

代码语言:javascript
复制
I [2013-01-22 17:46:00]  INFO: Started on drbunix:///tmp/god.17165.sock
I [2013-01-22 17:46:00]  INFO: sidekiq move 'unmonitored' to 'up'
I [2013-01-22 17:46:00]  INFO: sidekiq moved 'unmonitored' to 'up'

使用$god start sidekiq我得到:

代码语言:javascript
复制
Sending 'start' command

The following watches were affected:
  sidekiq

但是我没有从上帝那里得到任何输出,没有任何东西写入sidekiq的日志中,我可以清楚地看到没有使用$ ps auxwww | grep sidekiq启动sidekiq进程。

代码语言:javascript
复制
# config.god

PROJECT_ROOT = ENV['PROJECT_ROOT'] || File.dirname(__FILE__) # Dir containing this file

# Sidekiq Process

God.watch do |w|
  w.name = "sidekiq"
  w.group = "conversion"
  w.dir = PROJECT_ROOT
  w.interval = 20.seconds
  w.start_grace = 10.seconds
  w.restart_grace = 10.seconds
  w.behavior(:clean_pid_file)
  # w.keepalive
  w.start = "bundle exec sidekiq -v -C #{File.join(PROJECT_ROOT, 'config.yml')}"
  w.stop = "bundle exec sidekiqctl stop '/Users/me/.god/pids/sidekiq.pid' 5"

  w.log = File.join(PROJECT_ROOT, 'log/god_sidekiq.log')

end
EN

回答 1

Stack Overflow用户

发布于 2015-02-04 02:03:29

试试这个:

代码语言:javascript
复制
# config.god

PROJECT_ROOT = ENV['PROJECT_ROOT'] || File.dirname(__FILE__) # Dir containing this file

# Sidekiq Process
pid_file = '/Users/me/.god/pids/sidekiq.pid'
God.watch do |w|
  w.name = "sidekiq"
  w.group = "conversion"
  w.dir = PROJECT_ROOT
  w.interval = 20.seconds
  w.start_grace = 10.seconds
  w.restart_grace = 10.seconds
  w.pid_file = pid_file
  w.behavior(:clean_pid_file)

  w.start = "cd #{PROJECT_ROOT}; bundle exec sidekiq -v -C #{File.join(PROJECT_ROOT, 'config.yml')} -P #{pid_file}&"
  w.stop = "cd #{PROJECT_ROOT}; bundle exec sidekiqctl stop #{pid_file} 5"

  w.log = File.join(PROJECT_ROOT, 'log/god_sidekiq.log')

  # determine the state on startup
  w.transition(:init, {true => :up, false => :start}) do |on|
    on.condition(:process_running) do |c|
      c.running = true
    end
  end

  # determine when process has finished starting
  w.transition([:start, :restart], :up) do |on|
    on.condition(:process_running) do |c|
      c.running = true
    end

    # failsafe
    on.condition(:tries) do |c|
      c.times = 5
      c.transition = :start
    end
  end

  # start if process is not running
  w.transition(:up, :start) do |on|
    on.condition(:process_exits)
  end

  # lifecycle
  w.lifecycle do |on|
    on.condition(:flapping) do |c|
      c.to_state = [:start, :restart]
      c.times = 5
      c.within = 5.minute
      c.transition = :unmonitored
      c.retry_in = 10.minutes
      c.retry_times = 5
      c.retry_within = 2.hours
    end
  end
end
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/14464934

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档