7

目前我正在一个命令提示符下执行此操作

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 命令不会杀死它们,它只会让它们成为没有父母的孤儿。

有什么想法可以杀死整个生成的进程及其所有子进程吗?

4

2 回答 2

5

我最终通过以下方式解决了这个问题

首先我安装了 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为不那么令人反感的东西,但这是解决方案的要点。

于 2011-12-07T12:55:21.560 回答
-2

One-script solution without any gems. Run the script, CTRL-C to stop everything:

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
于 2015-01-09T13:35:13.257 回答