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

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

DDD
DDDオリジナル
2024-11-11 01:19:02895ブラウズ

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 サイトの他の関連記事を参照してください。

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