Forse questo aiuterà qualcun altro a cercare di ottenere funzionalità di timeout simile, ma deve raccogliere il uscita dal comando shell.
Ho adattato il metodo di @ shurikk per lavorare con Ruby 2.0 e un codice da Fork child process with timeout and capture output per raccogliere l'output.
def exec_with_timeout(cmd, timeout)
begin
# stdout, stderr pipes
rout, wout = IO.pipe
rerr, werr = IO.pipe
stdout, stderr = nil
pid = Process.spawn(cmd, pgroup: true, :out => wout, :err => werr)
Timeout.timeout(timeout) do
Process.waitpid(pid)
# close write ends so we can read from them
wout.close
werr.close
stdout = rout.readlines.join
stderr = rerr.readlines.join
end
rescue Timeout::Error
Process.kill(-9, pid)
Process.detach(pid)
ensure
wout.close unless wout.closed?
werr.close unless werr.closed?
# dispose the read ends of the pipes
rout.close
rerr.close
end
stdout
end
che non è vero. La shell secondaria che esegue il comando dovrebbe terminare quando termina il processo ruby parent. Si prega di dare un esempio più specifico. –
@BenLee: il processo padre non termina quando scade il timeout. –
@ MladenJablanović, in un rapido esperimento lo fa. Ho creato un file rubino che non ha fatto altro che: 'richiede 'timeout'; Timeout :: timeout (100) {'sleep 500'}'. Mentre lo eseguo, eseguo 'ps aux | grep sleep' e vedi il processo del sonno. Quindi invio SIGKILL al processo di ruby, e di nuovo eseguo 'ps aux | grep sleep' e non vede più il processo figlio. –