草庐IT

进程信号

全部标签

ruby - Ruby 的 stdlib Logger 类能否安全地处理来自多个进程的编写器?

我正在开发一个需要进行日志记录的Ruby库。理想情况下,我希望多个工作进程能够登录同一个文件。查看来自Ruby标准库的Logger类的源代码,我看到努力从多个线程同步写入日志(正如对IsRuby'sstdlibLoggerclassthread-safe?的回答中所指出的)。当多个进程写入同一个日志文件时,似乎存在类似的问题:根据底层决定缓冲/拆分写入的方式,每个日志消息可能无法保持其完整性。那么,有没有一种方法可以使用标准的Logger类来允许多个进程安全地记录到一个文件中?如果不是,这在Ruby项目中通常是如何完成的?这就是我所说的“安全”的意思:每个日志行都是“原子的”——在下一

ruby - 使用 Monit 监控 ruby​​ 进程

我有一堆长时间运行的Ruby脚本,我想确保每30秒左右运行一次。我通常通过简单地启动命令rubyscript-name.rb我如何配置monit来管理这些脚本?更新:我试着关注thismethodtocreateawrapperscript然后它会启动ruby​​进程,但它似乎没有创建.pid文件并且键入“./wrapper-scriptstop”什么也没做:/我应该在ruby​​中编写pid还是使用包装脚本来创建monit所需的pid? 最佳答案 MonitWiki有很多配置示例:http://mmonit.com/wiki/Mo

ruby - 如何在 Ruby 中使用信号阻塞

如何在Ruby中阻止某些信号?(即sigprocmask,如此处所述:http://www.chemie.fu-berlin.de/chemnet/use/info/libc/libc_21.html#SEC371)这是我的示例代码pid=forkdotrap('INT')doputs"Gracefulshutdown..."puts"goodbye"exit0endloopdothis_could_be_interruptedsomething_that_must_not_be_interruptedthis_could_be_interrupted_tooendendsleep5P

ruby-on-rails - 使用 Rails 3 的自定义守护进程

我正在尝试创建一个加载Rails环境的自定义守护进程。我的环境如下:ruby-1.9.2-p180rails3.0.5我做了以下事情:-安装守护进程gem-已安装的daemon_generator插件可在此处找到:https://github.com/dougal/daemon_generator-生成一个守护进程:railsgeneratedaemonlistener这一切都很好。当我运行守护程序时,它会工作。但是,一旦我尝试访问事件记录对象(如尝试检索用户),它就会崩溃。***belowyoufindthemostrecentexceptionthrown,thiswillbeli

ruby 信号量?

我正致力于在Ruby中实现“FairBarbershop”问题。这是一份类作业,但我不是要找任何讲义。我一直在疯狂地搜索,但我似乎无法找到一个信号量的Ruby实现来镜像在C中找到的信号量。我知道有Mutex,这很棒。单一实现,正是那种信号量应该做的。然后是条件变量。我认为这会很好地解决问题,但是看看这些,每个等待调用都需要一个Mutex,在我看来我无法将数值放入信号量(例如,我有七个理发店,3理发师等)。我想我需要一个计数信号量,但我认为Ruby没有(据我所知)在其核心中包含这样一个类,这有点奇怪。谁能帮我指出正确的方向? 最佳答案

c - 如何在 Mac OS X 上使用 ulimit 或每个进程为 C 或 Ruby 程序更改堆栈大小?

似乎为C程序或Ruby程序(使用C堆栈)设置堆栈大小的推荐方法是使用ulimit。在Bash外壳中。但是$ulimit-s8192$ulimit-s16384-bash:ulimit:stacksize:cannotmodifylimit:Operationnotpermitted和sudo也没有帮助。有没有办法将其设置为16MB、32MB或64MB?我认为应该有一种方法可以在每次程序调用时设置它,而不是同时设置系统范围的参数?现在8192可能意味着8MB,如果与一个进程可以使用的内存量相比,这是非常小的,有时最多2GB的RAM。(更新注释:ulimit-a可以显示其当前值)。(更新2

ruby-on-rails - 在 Ubuntu 上将 Sidekiq 作为守护进程运行

如何在Ubuntu上将sidekiq作为守护进程运行?如果我运行bundleexecsidekiq-D我得到invalidoption:-D,有没有办法在没有其他Controller的情况下运行它,比如god,upstart。..? 最佳答案 Daemonizesidekiq有一个选项,只需传递-d选项commit 关于ruby-on-rails-在Ubuntu上将Sidekiq作为守护进程运行,我们在StackOverflow上找到一个类似的问题: http

ruby - 上帝启动了太多进程

我有一个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

ruby - 从 fork 进程返回数据

如果我这样做Process.forkdoxend我怎么知道x返回了什么(例如true/fase/string)?(写入文件/数据库不是一种选择...) 最佳答案 我们实际上只需要在Railsisolationtesting中处理这个问题.我发布了一些onmyblog.基本上,您要做的是在父项和子项中打开一个管道,然后让子项写入管道。这是在子进程中运行block内容并取回结果的简单方法:defdo_in_childread,write=IO.pipepid=forkdoread.closeresult=yieldMarshal.dum

ruby-on-rails - 多进程VS多线程服务器最受益于什么?

谁能解释一下每种并发方式的瓶颈是什么?Unicorn(基于进程)和Puma(基于线程)等服务器。是否每种方法都更喜欢CPU内核?线程?或者只是时钟速度?还是特殊组合?如何确定在使用专用服务器的情况下所需的最佳CPU特性?如何确定Unicorn的最佳worker数量,或Puma的threads数量? 最佳答案 Unicorn是基于进程的,这意味着每个ruby​​实例都必须存在于自己的进程中。每个进程可能在500mb左右,这将很快耗尽系统资源。基于线程的Puma理论上不会使用相同数量的内存来获得相同数量的并发。Unicorn,由于是多个