我正在尝试监视以在CentOS服务器上重新启动我的sidekiq服务。在尝试了多种解决方案之后,我很困惑,仍然无法启动该服务。

我来自monit.d的sidekiq文件:

check process sidekiq
  with pidfile /var/www/App/tmp/pids/sidekiq.pid
  start program = "/bin/bash -l -c 'sudo cd /var/www/App && bundle exec sidekiq --index 0 --pidfile /var/www/App/tmp/pids/sidekiq.pid --environment production --logfile /var/www/App/log/sidekiq.log --daemon'" as uid deploy and gid deploy
  stop program = "/bin/bash -l -c 'cd /var/www/App && bundle exec sidekiqctl stop /var/www/App/tmp/pids/sidekiq.pid 10'" as uid deploy and gid deploy
  if totalmem is greater than 512 MB for 2 cycles then restart
  if 3 restarts within 5 cycles then timeout


如果我手动运行启动程序命令,它将启动sidekiq正常,但monit似乎无能为力。只是想出了:

[BST Oct  6 11:51:17] error    : 'sidekiq' process is not running
[BST Oct  6 11:51:17] info     : 'sidekiq' trying to restart
[BST Oct  6 11:51:17] info     : 'sidekiq' start: /bin/bash
[BST Oct  6 11:52:47] error    : 'sidekiq' failed to start


因此,它包括文件,但以某种方式无法从脚本启动服务。

会是什么一些权限问题?

最佳答案

您需要更新到最新的Monit版本(5.14)。
删除当前的monit安装并按照以下说明进行操作:

https://rtcamp.com/tutorials/monitoring/monit/

希望能帮助到你!

PS:在此处找到解决方案:https://bitbucket.org/tildeslash/monit/issues/109/failed-to-stop-always-after-60-seconds

关于ruby-on-rails - Monit无法重新启动sidekiq,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/32968215/

10-14 01:51