>백엔드 개발 >Golang >Go에서 콘솔과 파일에 동시에 로그인하는 방법은 무엇입니까?

Go에서 콘솔과 파일에 동시에 로그인하는 방법은 무엇입니까?

DDD
DDD원래의
2024-11-11 01:19:02897검색

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

Go에서 콘솔과 파일에 동시에 로깅

로그 메시지를 파일로 보내기 위해 코드는 일반적으로 log.SetOutput(logFile)을 사용합니다. . 그러나 콘솔 출력과 파일 로깅을 모두 원하는 경우 io.MultiWriter를 사용하는 솔루션이 있습니다.

io.MultiWriter란 무엇입니까?

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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.