我在生产网站上使用Resque。当我部署时,我希望GOD停止所有worker然后重新启动它们,因为有时我们更改类的代码并重新排队失败的作业。问题是,当我执行godstopresque时,rake实际上并没有停止,工作人员仍然活着并使用旧代码,这给我带来了各种各样的问题。即使我“上帝终止”它也不会杀死worker。现在,我正在使用shell脚本来杀死工作人员,但由于我有不止一台服务器,所以在所有生产服务器上进行操作非常痛苦。这是我的上帝配置文件:rails_env=ENV['RAILS_ENV']||"production"rails_root=ENV['RAILS_ROOT']||"/
我有这个文件rails_env=ENV['RAILS_ENV']||'development'rails_root=ENV['RAILS_ROOT']||"/home/luiz/rails_dev/api"God.watchdo|w|w.name="unicorn"w.interval=30.seconds#default#unicornneedstoberunfromtherailsrootw.start="cd#{rails_root}&&unicorn_rails-cconfig/unicorn.rb-E#{rails_env}"#QUITgracefullyshutsdownw
我有一个Rails网站和一个在linodevps上运行的小型Minecraft服务器。我正在运行minecraft作为基于init.d文件的ram服务器的自定义服务。因为我使用God来监控我的Rails网站,所以我想我也会将它用于我的世界,但它似乎无法以任何方式识别该服务。条件检测不到它的存在。:process_running始终返回false,无论它是否正在运行,并且在未运行时无法启动它。更让人困惑的是:memory_usage和:cpu_usage始终为零。我的/etc/init.d/minecraft文件在这里:http://pastie.org/2760483它工作得非常好,“
我使用passenger服务我的软件。它产生许多ruby进程。有时其中一颗ruby会变得肿胀,我希望它死掉。我希望用上帝来达到这个目的。我的想法是监控所有这些ruby,如果它在3个周期内消耗超过500MB的内存,上帝应该尝试优雅地杀死它。如果它还活着超过5分钟,那么上帝应该不会优雅地杀死它。在我看来,上帝总是试图再次运行该服务,因此它迫使我们提供启动命令。是否可以只使用god来杀死不良行为的进程,并让passengerspawner在必要时将它们带回来? 最佳答案 您问题的答案在于问题本身。您可以使用godgem终止ruby进程这是
我正在尝试了解如何监控travis-ci的resqueworker|与god以这样一种方式停止resquewatchviagod不会留下陈旧的工作进程。在下文中,我谈论的是工作进程,而不是fork作业子进程(即队列一直是空的)。当我像这样手动启动resqueworker时:$QUEUE=buildsrakeresque:work我会得到一个进程:$psx|grepresque7041s001S+0:05.04resque-1.13.0:Waitingforbuilds一旦我停止工作任务,这个过程就会消失。但是当我开始与上帝(exactconfigurationishere,基本上与re
我有一个god脚本,它应该监视两个stalker进程。问题是24小时后它启动了太多进程。这是神脚本。rails_root=File.expand_path("../..",__FILE__)2.timesdo|n|God.watchdo|w|w.group="app-scripts"w.name="run-#{n}"w.interval=30.secondsw.dir=File.dirname(__FILE__)w.env={"BUNDLE_GEMFILE"=>"#{rails_root}/Gemfile","RAILS_ENV"=>"production","BEANSTALK_UR
关闭。这个问题需要更多focused.它目前不接受答案。想改进这个问题吗?更新问题,使其只关注一个问题editingthispost.关闭7年前。Improvethisquestion使用哪个进行过程监控?为什么?
网络上是否有关于如何使用Monit监控delayed_job的示例??我能找到的所有东西都使用God,但我拒绝使用上帝,因为在Ruby中长时间运行的进程通常很糟糕。(上帝邮件列表中的最新帖子?GodMemoryUsageGrowsSteadily。)更新:delayed_job现在带有samplemonitconfig基于这个问题。 最佳答案 下面是我如何让它工作的。使用collectiveideaforkofdelayed_job除了积极维护之外,这个版本还有一个不错的script/delayed_job可以与monit一起使用的
我在我的ruby应用程序中做了几项上帝会照顾的工作。但是,当服务器重新启动时,作业停止。我想避免这种情况,所以我在我的服务器上制作了这个脚本。看起来像这样。my_app.sh#!/bin/bash#godtasks#case$1instart)/usr/local/rvm/gems/ruby-1.9.3-p194/bin/god/usr/local/rvm/gems/ruby-1.9.3-p194/bin/godstart/usr/local/rvm/gems/ruby-1.9.3-p194/bin/godload/usr/local/Linux/apache2/www/hej.s
有没有可能让上帝依次启动两个过程?我正在使用依赖于Redis的Sidekiq。我想启动Redis,然后启动Sidekiq,我设置了两个独立的watch,它们可以独立工作,但是当我运行时:$god-c"./config.god"-D看来是大神同时启动,导致Sidekiq无法连接到Redis服务器报错。我的上帝配置文件如下:#config.godPROJECT_ROOT=ENV['PROJECT_ROOT']||"/Path/to/app"God.watchdo|w|w.name="redis-server"w.group='conversion-api'w.interval=30.sec