草庐IT

进程退出

全部标签

ruby - 如何在 ruby​​ 中控制(启动/终止)后台进程(服务器应用程序)

我正在尝试通过ruby​​为集成测试(实际上是规范)设置一个服务器,但不知道如何控制该过程。所以,我要做的是:为我的gem运行一个执行集成规范的rake任务任务需要先启动服务器(我使用webrick),然后运行规范执行规范后,它应该会杀死webrick,这样我就不会留下一些未使用的后台进程webrick不是必需的,但它包含在ruby​​标准库中,因此能够使用它会很棒。希望有人能提供帮助!附言。我在linux上运行,所以让这个适用于windows的工作不是我的主要优先事项(现在)。 最佳答案 标准方法是使用系统函数fork(复制当前进

ruby - Office 365 Rest API - 守护进程周身份验证

我正在尝试构建一个Ruby守护进程服务来访问Office365restAPI。最近可以通过OAuth“client_credentials”流程来执行此操作,详见此博文:https://learn.microsoft.com/en-us/archive/blogs/exchangedev/building-daemon-or-service-apps-with-office-365-mail-calendar-and-contacts-apis-oauth2-client-credential-flow我正在努力生成有效的访问token。token端点返回一个JWT,但是当使用这个to

ruby - 如何在 pry 中退出循环

如果你继续输入'n',你将循环100次,我怎么能离开每个循环并继续从第7行开始调试而不退出循环然后自动运行剩余的代码,exit!!!的行为不适合我,因为我想在退出循环后继续调试代码。1:require'pry'2:=>3:binding.pry4:(1..100).eachdo|x|5:printx6:end7:8:print"hi" 最佳答案 你可以使用disable-pry命令 关于ruby-如何在pry中退出循环,我们在StackOverflow上找到一个类似的问题:

ruby - ruby 中的线程安全外部进程,以及检查退出状态

我想在Ruby中运行一段调用外部程序的线程安全脚本,然后检查该外部程序的退出状态。最好的方法是什么?到目前为止,我一直在检查$?,但我认为我遇到了与程序其他部分的竞争条件。下面是一些示例代码:Thread.newdo`external_program`if$?.exitstatus==0#itworked.else#itdidn'twork.endend理想情况下,我会做类似的事情Process.new(`external_program`).exitstatus因此exitstatus与that进程密不可分,而不是恰好完成的最后一个进程。有什么办法吗? 最

ruby - 在 Ruby 中使用 Unix 进程控制方法

RyanTomayko用thispost引发了一场激烈的Storm关于使用Unix进程控制命令。Weshouldbedoingmoreofthis.Alotmoreofthis.I'mtalkingaboutfork(2),execve(2),pipe(2),socketpair(2),select(2),kill(2),sigaction(2),andsoonandsoforth.Theseareourfriends.Theywantsobadlyjusttohelpus.我有一些代码(DataMapper的delayed_job克隆,我认为它适合这个,但我不清楚如何利用列出的命令。

ruby-on-rails - Rails 不会在第一次 CTRL-C 时退出

没有Rails命令会在第一次CTRL-C时退出。所以railss或railsc需要我再次按下controlCTRL-C,而以前根本不需要CTRL-C的命令(例如rakeroutes/db:migrate)现在需要我按下它。我的任何队友都没有出现该问题。我在OSX上使用iTerm2。应用程序中没有“救援异常”实例。我刚刚使用brew重新安装了mysql,但问题仍然存在。Rails版本4.0.5和SQLServer版本5.6.27。知道问题出在哪里吗?[2016-01-1316:18:33]INFOWEBrick1.3.1[2016-01-1316:18:33]INFOruby2.1.2(

ruby - 如何将数据通过管道传输到通过标准输入上的 Net::SSH 启动的进程?

我正在本地机器上生成数据源,我想通过Net::SSH将其传输到远程进程。有点像echofoosball|sed's/foo/bar/g'只是echofoosball部分将是本地计算机上的数据馈送。我不要找的是:data="foosball"ssh.exec!("echo#{data}|sed's/foo/bar/g'")我真的想要实时将数据流传输到流程中;) 最佳答案 好吧,我明白了:#!/usr/bin/envrubyrequire'rubygems'require'net/ssh'res=""c=Net::SSH.start("

ruby - 如何规范退出或中止的方法

我有一个从CLI触发的方法,它有一些显式退出或中止的逻辑路径。我发现在为此方法编写规范时,RSpec将其标记为失败,因为退出是异常。这是一个简单的例子:defcli_methodifconditionputs"Everything'sokay!"elseputs"GTFO!"exitendend我可以使用shouldraise_error(SystemExit)将规范包装在lambda中,但这会忽略block内发生的任何断言。需要明确的是:我不是在测试导出本身,而是在它之前发生的逻辑。我该如何指定这种类型的方法? 最佳答案 只需将您

ruby - 如何将 Rubymine IDE 调试器附加到 shell 进程?

我想使用Rubymine的IDE调试器来调试在命令shell中运行的ruby​​进程,因为它是生成的,例如通过“railsconsole”。在运行网络服务器(从Rubymine中)或测试套件(也从Rubymine中运行)时,我已经从调试器中获得了很大的收获。但是,如果该进程不是由Rubymine启动的,我不知道如何附加调试器。我在带有SunJava1.6.0_26、RubyREE1.8.7和最新调试gems的Ubuntu上使用Rubymine3.2.4版本:ruby-debug-base(0.10.4)ruby-debug-ide(0.4.17.beta8)想法?

ruby-on-rails - Phusion Passenger 如何重用线程和进程?

我正在设置一个Apache2网络服务器,使用PhusionPassenger运行多个RubyonRails网络应用程序。我知道Passenger生成Ruby进程来处理请求。我有以下问题:如果必须同时处理多个请求,Passenger会生成多个进程还是多个(Ruby)线程?如何配置它以使其始终生成单线程进程?如果我有两个Rails应用程序,假设对应用程序A的请求进入进程1,然后对应用程序B的请求到达。进程1是否也可能处理此请求?什么时候以及如何做到这一点?换句话说,是否允许一个进程处理多个Rails应用程序的请求?我在多个URL和多个虚拟主机(例如http://和https://)中导出了