草庐IT

pcntl_fork

全部标签

ruby - 在 jRuby 中使用 'fork' 生成进程的替代方案?

在MRIRuby中我可以这样做:deftransferinternal_server=self.init_serverpid=forkdointernal_server.runend#Maketheserverprocessrunindependently.Process.detach(pid)internal_client=self.init_client#Dootherstuffwithconnectingtointernal_server...internal_client.post('somedata')ensure#KillserverProcess.kill('KILL',

ruby-on-rails - Fork、Ruby、ActiveRecord 和 Fork 上的文件描述符

我知道当我们fork一个进程时,子进程会继承父进程的打开文件描述符和偏移量的副本。根据手册页,这指的是父级使用的相同文件描述符。基于以下程序中的理论puts"Process#{Process.pid}"file=File.open('sample','w')forked_pid=forkdosleep(10)puts"Writingtofilenow..."file.puts("HelloWorld.#{Time.now}")endfile.puts("Welcometowinterofmydiscontent#{Time.now}")file.closefile=nil问题一:当父进

ruby-on-rails - 使用 Kernel#fork 进行后台进程,专业人士?缺点?

我想知道使用fork{}从Rails应用程序“后台”处理是否是个好主意...从我收集到的fork{my_method;Process#setsid}实际上做了它应该做的事情。1)创建另一个具有不同PID的进程2)不中断调用过程(例如它继续w/o等待fork完成)3)执行子进程直到它完成..这很酷,但这是个好主意吗?fork到底在做什么?它会在内存中创建我的整个railsmongrel/passenger实例的重复实例吗?如果是这样那就太糟糕了。或者,它是否以某种方式在不消耗大量内存的情况下完成。我的最终目标是取消我的后台守护进程/队列系统,转而支持这些进程的fork(主要是发送电子邮件

Ruby - fork 进程上的 set_trace_func

我想实现以下目标:构建一个Ruby命令行实用程序来注册一些set_trace_func事件,然后调用您传递给它的任何ruby​​可执行参数(比如rspec)。注册的事件然后转移到调用的命令。myutility的伪代码:set_trace_func()#Setsomeeventshereexec(ARGV.join(''))#Executeargumentpassed然后调用myutilityrspec。我的目标是实际在任意命令上注册跟踪点(只要它们使用ruby​​垫片)。我尝试过的事情:exec不起作用,原因很明显(它完全取代了进程)。popen、系统、反引号。这些启动了一个独立的过程

ruby - ruby 中的 fork 和线程

我在一台有两个处理器的机器上运行一个程序,当我做一个fork时,子线程是作为native线程创建的,或者它就像一个绿色线程/协程。子进程是与父进程同时运行还是只是并行运行? 最佳答案 fork()的工作一般是生成一个新的、独立的进程,复制页表,并将调用fork()的进程拥有的所有页面标记为该进程中的写时复制。然后,fork()在两个进程中返回(返回值让相应的进程知道它是哪个进程)。在具有多个处理器(或处理器核心)的系统上,您可以正常(假设您确实有一个支持SMP的系统,cpu亲和性不会阻止它)期望这两个进程使用这两种处理器,但您不能严

ruby-on-rails - 在 Github 上 fork Ruby/Rails gem 的正确协议(protocol)/礼仪是什么,可以作为持续的并行 fork 进行维护?

最近我使用了一个由单个开发人员创建的不错的gem,它托管在Github上。在我的工作中,我不得不对它进行一些实质性的修改,添加一些改进。有些是特定于项目的,有些是特定于gem的,还有一些是独立的改进。对于特定于gem的改进(例如,错误修复),我fork了存储库,应用了修复,并提出了拉取请求。然后,然而,我注意到独立的改进有点属于原始gem的并行、持续的分支类别。更清楚地说,你以前见过它;我重写了原始gem的View以使用TwitterBootstrap框架。因此,我也将它推送到了Github,但是,当然,我没有提出拉取请求——相反,我更新了README以解释不同之处,并感谢gem的原作

ruby - 在 Windows 中使用 fork 和 Ruby

当我在Windows上调用Kernel.fork()时,出现此错误:!!Unexpectederrorwhileprocessingrequest:fork()functionisunimplementedonthismachine在Windows上是否有替代的fork方法? 最佳答案 试试spawn()-它是为Windows实现的。 关于ruby-在Windows中使用fork和Ruby,我们在StackOverflow上找到一个类似的问题: https:/

ruby-on-rails - 是否可以在 Heroku Cedar 上运行 capybara-webkit(即 fork 的 webkit_server)?

我需要在Rails应用程序中运行capybara-webkit以启用带有JavaScript支持的headlessWeb浏览(即不用于测试/CI目的,webrat或其他验收测试驱动程序/框架将不起作用)。我想知道这在Heroku部署中是否可行,特别是因为它需要QtWebKit以及通过套接字通信forkwebkit_server进程的能力。我愿意接受关于如何在Heroku上进行这项工作的创造性想法(例如,一组workerdynos)。我希望有人能更好地处理Heroku环境中存在的限制,或者可以断然排除这种可能性,这样我就可以在必要时转向AWSEC2。搜索这个往往会发现很多关于CI服务器的

Ruby - fork、exec、detach ....我们这里有竞争条件吗?

简单的例子,它在我的平台上不起作用(Ruby2.2,Cygwin):#!/usr/bin/rubybacktt=fork{exec('mintty','/usr/bin/zsh','-i')}Process.detach(backtt)exit这个小程序(当从shell启动时)应该跨越一个终端窗口(mintty)然后让我回到shell提示符。但是,虽然它确实创建了mintty窗口,但之后我没有shell提示符,而且我无法在调用shell中键入任何内容。但是当我在分离之前引入一个小的延迟时,无论是使用“sleep”,还是通过在标准输出上打印一些东西,它都会按预期工作:#!/usr/bin

ruby - 从 fork 进程返回数据

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