目前我在一个命令提示符
中执行此操作require 'win32/process'
p = Process.spawn("C:/ruby193/bin/bundle exec rails s")
puts p
Process.waitpid(p)
然后在另一个
require 'win32/process'
Process.kill(1,<p>)
问题是我生成的进程(在这种情况下是Rails服务器)产生了一系列子进程。 kill命令不会杀死它们,只是让它们孤立无父。
任何想法如何杀死整个衍生过程及其所有孩子?
答案 0 :(得分:4)
我最终以下列方式解决了这个问题
首先我安装了sys-proctable gem
gem install 'sys-proctable'
然后使用最初发布的代码到spawn
进程,并使用以下代码将其删除(为简洁省略了错误处理)
require 'win32/process'
require 'sys/proctable'
include Win32
include Sys
to_kill = .. // PID of spawned process
ProcTable.ps do |proc|
to_kill << proc.pid if to_kill.include?(proc.ppid)
end
Process.kill(9, *to_kill)
to_kill.each do |pid|
Process.waitpid(pid) rescue nil
end
当然,您可以将kill 9
更改为冒犯,但这是解决方案的要点。
答案 1 :(得分:-2)
没有任何宝石的单脚本解决方案。运行脚本CTRL-C以停止所有操作:
processes = []
processes << Process.spawn("<your process>")
loop do
trap("INT") do
processes.each do |p|
Process.kill("KILL", p) rescue nil
Process.wait(p) rescue nil
end
exit 0
end
sleep(1)
end