Go のコンソールとファイルに同時にログを記録する
ログ メッセージをファイルに送信するには、通常、コードでは log.SetOutput(logFile) を使用します。 。ただし、コンソール出力とファイルへのログ記録の両方が必要な場合は、io.MultiWriter を使用した解決策を次に示します。
io.MultiWriter とは?
An io.MultiWriter複数の宛先に同時にデータを書き込むことができます。これは、Unix tee コマンドの動作に似ています。
解決策
コンソールとファイルの両方にログを記録するには:
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)
例
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 サイトの他の関連記事を参照してください。