ホームページ バックエンド開発 Golang Goで実行出力をリアルタイムでロガーにリダイレクトする方法は?

Goで実行出力をリアルタイムでロガーにリダイレクトする方法は?

Nov 08, 2024 am 01:59 AM

How to Redirect Execution Output to a Logger in Real-time in Go?

Go のロガーへの実行出力のリダイレクト

Go では、exec パッケージは外部コマンドを実行するためのメカニズムを提供します。 CombinedOutput メソッドはコマンドの終了後に出力全体をキャプチャできますが、長時間実行されているプロセスや未完了のプロセスには適していない可能性があります。

コマンドの出力をリアルタイムでロガーにリダイレクトするには、柔軟な対応が求められます。 1 つの手法では、パイプを使用してコマンドの出力をロガーに接続します。

コード スニペットの例を次に示します。

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

import (

    "bufio"

    "log"

    "os/exec"

)

 

func main() {

    cmd := exec.Command("yes")

 

    // Create a pipe to connect the command's stdout to the logger

    stdout, err := cmd.StdoutPipe()

    if err != nil {

        log.Fatalf("Failed to create stdout pipe: %v", err)

    }

 

    // Start the command

    if err := cmd.Start(); err != nil {

        log.Fatalf("Failed to start command: %v", err)

    }

 

    // Create a buffered reader to read the output line by line

    in := bufio.NewScanner(stdout)

 

    // Read the output and log it in real-time

    for in.Scan() {

        log.Printf(in.Text())

    }

 

    if err := in.Err(); err != nil {

        log.Printf("Error reading command output: %v", err)

    }

}

ログイン後にコピー

この例では、Stderr ストリームは、別のゴルーチン。コマンドの出力をロガーにパイプすることで、開発者はそのリアルタイム出力をキャプチャしてログに記録できるため、アプリケーション内のプロセスの監視とトラブルシューティングが容易になります。

以上がGoで実行出力をリアルタイムでロガーにリダイレクトする方法は?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットな記事タグ

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

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

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

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

Go Language Packのインポート:アンダースコアとアンダースコアなしの違いは何ですか? Go Language Packのインポート:アンダースコアとアンダースコアなしの違いは何ですか? Mar 03, 2025 pm 05:17 PM

Go Language Packのインポート:アンダースコアとアンダースコアなしの違いは何ですか?

GOでテスト用のモックオブジェクトとスタブを書くにはどうすればよいですか? GOでテスト用のモックオブジェクトとスタブを書くにはどうすればよいですか? Mar 10, 2025 pm 05:38 PM

GOでテスト用のモックオブジェクトとスタブを書くにはどうすればよいですか?

Beegoフレームワークのページ間で短期情報転送を実装する方法は? Beegoフレームワークのページ間で短期情報転送を実装する方法は? Mar 03, 2025 pm 05:22 PM

Beegoフレームワークのページ間で短期情報転送を実装する方法は?

トレースツールを使用して、GOアプリケーションの実行フローを理解するにはどうすればよいですか? トレースツールを使用して、GOアプリケーションの実行フローを理解するにはどうすればよいですか? Mar 10, 2025 pm 05:36 PM

トレースツールを使用して、GOアプリケーションの実行フローを理解するにはどうすればよいですか?

GOのジェネリックのカスタムタイプ制約を定義するにはどうすればよいですか? GOのジェネリックのカスタムタイプ制約を定義するにはどうすればよいですか? Mar 10, 2025 pm 03:20 PM

GOのジェネリックのカスタムタイプ制約を定義するにはどうすればよいですか?

Go言語でファイルを便利に書く方法は? Go言語でファイルを便利に書く方法は? Mar 03, 2025 pm 05:15 PM

Go言語でファイルを便利に書く方法は?

MySQLクエリ結果リストをGO言語のカスタム構造スライスに変換する方法は? MySQLクエリ結果リストをGO言語のカスタム構造スライスに変換する方法は? Mar 03, 2025 pm 05:18 PM

MySQLクエリ結果リストをGO言語のカスタム構造スライスに変換する方法は?

Linterと静的分析ツールを使用して、GOコードの品質と保守性を向上させるにはどうすればよいですか? Linterと静的分析ツールを使用して、GOコードの品質と保守性を向上させるにはどうすればよいですか? Mar 10, 2025 pm 05:38 PM

Linterと静的分析ツールを使用して、GOコードの品質と保守性を向上させるにはどうすればよいですか?

See all articles