Golang で os/exec で開始されたプロセスを終了する
Golang でプロセスを操作するときの一般的なニーズの 1 つは、プロセスが自然に終了する前にプロセスを終了することです。完了。たとえば、予想よりも時間がかかったり、予期しない入力を受け取ったりした場合、プロセスを終了することができます。この記事では、os/exec で開始されたプロセスを終了するために Golang で利用できるさまざまな方法について説明します。
exec を実行して終了します。プロセス:
os/exec パッケージは以下を提供します。プロセスを終了する簡単な方法。 exec.Cmd.Process フィールドを取得すると、その Kill メソッドを直接呼び出すことができます。
// Start a process: cmd := exec.Command("sleep", "5") if err := cmd.Start(); err != nil { log.Fatal(err) } // Kill it: if err := cmd.Process.Kill(); err != nil { log.Fatal("failed to kill process: ", err) }
タイムアウト後に exec.Process を実行して終了します:
指定したタイムアウト後にプロセスを自動的に終了するには、コンテキスト パッケージを利用できます。この例では、キャンセル可能なコンテキストを利用して 3 秒のタイムアウト後にプロセスを終了する方法を示します。
ctx, cancel := context.WithTimeout(context.Background(), 3*time.Second) defer cancel() if err := exec.CommandContext(ctx, "sleep", "5").Run(); err != nil { // This will fail after 3 seconds. The 5 second sleep will be interrupted. }
レガシー アプローチ (Go バージョン 1.7 より前の):
1.7 より前の Go バージョンでは、コンテキスト パッケージは利用できませんでした。そのため、タイムアウト後にチャネルとゴルーチンを使用してプロセスを終了するには、別のアプローチが必要でした。
// Start a process: cmd := exec.Command("sleep", "5") if err := cmd.Start(); err != nil { log.Fatal(err) } // Wait for the process to finish or kill it after a timeout (whichever happens first): done := make(chan error, 1) go func() { done <- cmd.Wait() }() select { case <-time.After(3 * time.Second): if err := cmd.Process.Kill(); err != nil { log.Fatal("failed to kill process: ", err) } log.Println("process killed as timeout reached") case err := <-done: if err != nil { log.Fatalf("process finished with error = %v", err) } log.Print("process finished successfully") }
これらのメソッドを使用すると、Golang の os/exec を使用して生成されたプロセスを効果的に終了でき、次の処理が可能になります。タイムアウトや予期しない動作などのプロセス管理シナリオ。
以上がGo で os/exec プロセスを正常に終了するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。