ホームページ > バックエンド開発 > Golang > Go でコンソールとファイルの両方に同時にログインするにはどうすればよいですか?

Go でコンソールとファイルの両方に同時にログインするにはどうすればよいですか?

DDD
リリース: 2024-11-11 01:19:02
オリジナル
892 人が閲覧しました

How to Log to Both Console and File Simultaneously in Go?

Go のコンソールとファイルに同時にログを記録する

ログ メッセージをファイルに送信するには、通常、コードでは log.SetOutput(logFile) を使用します。 。ただし、コンソール出力とファイルへのログ記録の両方が必要な場合は、io.MultiWriter を使用した解決策を次に示します。

io.MultiWriter とは?

An io.MultiWriter複数の宛先に同時にデータを書き込むことができます。これは、Unix tee コマンドの動作に似ています。

解決策

コンソールとファイルの両方にログを記録するには:

  1. ログ用ファイル:
logFile, err := os.OpenFile("log.txt", os.O_CREATE | os.O_APPEND | os.O_RDWR, 0666)
if err != nil {
    panic(err)
}
ログイン後にコピー
  1. コンソール出力とファイル出力を組み合わせる MultiWriter を作成します:
mw := io.MultiWriter(os.Stdout, logFile)
ログイン後にコピー
  1. デフォルトの出力先を設定しますログ:
log.SetOutput(mw)
ログイン後にコピー

package main

import (
    "log"
    "os"
    "io"
)

func main() {
    logFile, err := os.OpenFile("log.txt", os.O_CREATE | os.O_APPEND | os.O_RDWR, 0666)
    if err != nil {
        panic(err)
    }

    mw := io.MultiWriter(os.Stdout, logFile)
    log.SetOutput(mw)

    log.Println("This is a log message")
}
ログイン後にコピー

以上がGo でコンソールとファイルの両方に同時にログインするにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート