Golang で子プロセスを正常にシャットダウンする方法
Golang は、マルチプロセス プログラミングをサポートする強力なプログラミング言語です。 Go で子プロセスを開始するのは簡単ですが、それを閉じるにはいくつかのコツが必要です。この記事では、Golang で子プロセスを正常にシャットダウンする方法を紹介します。
1. サブプロセスの開始
Golang でのサブプロセスの開始は非常に簡単で、exec パッケージの Command 関数を使用できます。コマンドの開始例を次に示します。
cmd := exec.Command("ls", "-l") err := cmd.Start() if err != nil { log.Fatal(err) }
このコードは、「ls -l」コマンドの子プロセスを開始します。
2. 子プロセスを閉じる
子プロセスが完了したら、Wait 関数を呼び出して、子プロセスが閉じるのを待つ必要があります。ただし、子プロセスを無限ループで開始する場合、子プロセスをシャットダウンするには、より高度なテクニックが必要になります。
まず、子プロセスの PID を変数に保存する必要があります。これは、syscall パッケージの Getpid 関数を使用して実現できます。その後、子プロセスをシャットダウンする必要がある場合、syscall パッケージの Kill 関数を使用してオペレーティング システム シグナルを送信できます。
package main import ( "fmt" "os" "os/exec" "syscall" "time" ) func main() { cmd := exec.Command("sleep", "10") err := cmd.Start() if err != nil { fmt.Println(err) os.Exit(1) } pid := cmd.Process.Pid fmt.Printf("Child process started: %v\n", pid) time.AfterFunc(time.Second*5, func() { err := syscall.Kill(pid, syscall.SIGTERM) if err != nil { fmt.Println(err) } else { fmt.Printf("Child process %v terminated\n", pid) } }) cmd.Wait() fmt.Println("Parent process exiting.") }
このプログラムは、「sleep 10」コマンドで子プロセスを開始し、5 秒待ってから、SIGTERM シグナルを送信して子プロセスを強制終了します。 time.AfterFunc 関数を使用して 5 秒後に操作を実行し、syscall.Kill 関数を使用してシグナルを送信します。操作が完了したら、cmd.Wait 関数を使用して、子プロセスが閉じるのを待ちます。
3. 子プロセスを正常にシャットダウンする
上記の例では、子プロセスをシャットダウンするために SIGTERM シグナルを送信しました。このシグナルはプロセスによって捕捉され、プロセスはシグナルを捕捉した後にクリーンアップ作業を実行し、通常どおり終了します。
子プロセスがシグナルをキャッチしない場合は、SIGKILL シグナルを使用して子プロセスを強制的に閉じる必要があります。このシグナルは、プロセスにクリーンアップの機会を与えずに、プロセスを直接強制終了します。子プロセスを強制的に閉じると、プロセスが一時ファイルを残してシステム リソースを占有する可能性があります。
子プロセスを正常にシャットダウンするには、子プロセスに終了シグナルを送信します。このシグナルは子プロセスによってキャッチされ、キャッチ後にプロセスは安全にシャットダウンされます。
終了シグナルを使用するには、子プロセスのコードでシグナルをサポートする必要があります。 Golang では、これは OS パッケージの Signal 関数を通じて実現できます。終了シグナルをサポートするサブプロセスの例を次に示します。
package main import ( "fmt" "os" "os/signal" "syscall" "time" ) func main() { fmt.Println("Child process started.") sigchan := make(chan os.Signal, 1) signal.Notify(sigchan, syscall.SIGTERM) go func() { <-sigchan fmt.Println("Received SIGTERM signal, exiting...") os.Exit(0) }() // Start doing some meaningful work. for { fmt.Println("Working...") time.Sleep(time.Second) } }
このプログラムは無限ループを開始し、毎秒「Working...」を出力します。子プロセスのコードでは、シグナル チャネル sigchan を作成し、signal.Notify 関数を使用して SIGTERM シグナルをチャネルに送信します。
その後、信号を受信するまで無限ループで待機します。このシグナルを受信すると、終了メッセージを出力し、os.Exit 関数を使用してプロセスを終了します。
これで、終了シグナルをサポートするサブプロセスがすでにできました。次のコードを使用してそれを閉じることができます:
package main import ( "fmt" "os" "os/exec" "syscall" "time" ) func main() { cmd := exec.Command("./child") err := cmd.Start() if err != nil { fmt.Println(err) os.Exit(1) } pid := cmd.Process.Pid fmt.Printf("Child process started: %v\n", pid) time.AfterFunc(time.Second*5, func() { err := syscall.Kill(pid, syscall.SIGTERM) if err != nil { fmt.Println(err) } else { fmt.Printf("Child process %v terminated\n", pid) } }) cmd.Wait() fmt.Println("Parent process exiting.") }
このプログラムは test1 コマンドのサブプロセスを開始し、5 秒間待機します次に、SIGTERM シグナルを送信して子プロセスを閉じます。通常の状況では、子プロセスは終了メッセージを出力して正常に終了するはずです。
要約すると、Golang では子プロセスを閉じることはそれほど難しくありません。 syscall パッケージの Kill 関数を使用してシグナルを送信したり、子プロセスのコードで終了シグナルをサポートして子プロセスを正常にシャットダウンしたりできます。
以上がGolang で子プロセスを正常にシャットダウンする方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック









OpenSSLは、安全な通信で広く使用されているオープンソースライブラリとして、暗号化アルゴリズム、キー、証明書管理機能を提供します。ただし、その歴史的バージョンにはいくつかの既知のセキュリティの脆弱性があり、その一部は非常に有害です。この記事では、Debian SystemsのOpenSSLの共通の脆弱性と対応測定に焦点を当てます。 Debianopensslの既知の脆弱性:OpenSSLは、次のようないくつかの深刻な脆弱性を経験しています。攻撃者は、この脆弱性を、暗号化キーなどを含む、サーバー上の不正な読み取りの敏感な情報に使用できます。

この記事では、プロファイリングの有効化、データの収集、CPUやメモリの問題などの一般的なボトルネックの識別など、GOパフォーマンスを分析するためにPPROFツールを使用する方法について説明します。

この記事では、GOでユニットテストを書くことで、ベストプラクティス、モッキングテクニック、効率的なテスト管理のためのツールについて説明します。

この記事では、ユニットテストのためにGOのモックとスタブを作成することを示しています。 インターフェイスの使用を強調し、模擬実装の例を提供し、模擬フォーカスを維持し、アサーションライブラリを使用するなどのベストプラクティスについて説明します。 articl

この記事では、GENICSのGOのカスタムタイプの制約について説明します。 インターフェイスがジェネリック関数の最小タイプ要件をどのように定義するかを詳しく説明し、タイプの安全性とコードの再利用性を改善します。 この記事では、制限とベストプラクティスについても説明しています

この記事では、コードのランタイム操作に使用されるGoの反射パッケージについて説明します。シリアル化、一般的なプログラミングなどに有益です。実行やメモリの使用量の増加、賢明な使用と最高のアドバイスなどのパフォーマンスコストについて警告します

この記事では、GOでテーブル駆動型のテストを使用して説明します。これは、テストのテーブルを使用して複数の入力と結果を持つ関数をテストする方法です。読みやすさの向上、重複の減少、スケーラビリティ、一貫性、および

この記事では、トレースツールを使用してGOアプリケーションの実行フローを分析します。 手動および自動計装技術について説明し、Jaeger、Zipkin、Opentelemetryなどのツールを比較し、効果的なデータの視覚化を強調しています
