目前我在一个命令提示符下执行此操作
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 命令不会杀死它们,只会让它们成为孤儿,没有 parent 。
有什么想法可以杀死整个派生进程及其所有子进程吗?
最佳答案
我最终通过以下方式解决了这个问题
首先我安装了 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
更改为不那么攻击性的东西,但这是解决方案的要点。
关于ruby - 在 Windows 上的 Ruby 中终止进程和子进程,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8212483/