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

DDD
풀어 주다: 2024-11-11 01:19:02
원래의
863명이 탐색했습니다.

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

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿