>백엔드 개발 >Golang >Go에서 파일에 로그를 성공적으로 쓰는 방법은 무엇입니까?

Go에서 파일에 로그를 성공적으로 쓰는 방법은 무엇입니까?

Patricia Arquette
Patricia Arquette원래의
2024-12-13 07:06:13553검색

How to Successfully Write Logs to a File in Go?

Go에서 파일에 로그 쓰기

Go를 사용하여 파일에 로그인하려는 시도에서 다음을 포함한 여러 접근 방식이 시도되었습니다.

func TestLogging(t *testing.T) {
    if !FileExists("logfile") {
        CreateFile("logfile")
    }
    f, err := os.Open("logfile")
    if err != nil {
        t.Fatalf("error: %v", err)
    }

    // attempt #1
    log.SetOutput(io.MultiWriter(os.Stderr, f))
    log.Println("hello, logfile")

    // attempt #2
    log.SetOutput(io.Writer(f))
    log.Println("hello, logfile")

    // attempt #3
    log.SetOutput(f)
    log.Println("hello, logfile")
}

그러나 로그파일(logfile)을 생성했음에도 불구하고 어떠한 정보도 기록되지 않았습니다.

해결책은 다음을 사용하는 것입니다. os.Open 대신 os.OpenFile을 사용하면 파일 액세스 권한을 더 효과적으로 제어할 수 있습니다. 다음 코드는 로그 파일에 성공적으로 기록됩니다.

f, err := os.OpenFile("testlogfile", os.O_RDWR | os.O_CREATE | os.O_APPEND, 0666)
if err != nil {
    log.Fatalf("error opening file: %v", err)
}
defer f.Close()

log.SetOutput(f)
log.Println("This is a test log entry")

이 접근 방식은 다음 플래그와 함께 os.OpenFile을 활용합니다.

  • os.O_RDWR: 읽기-쓰기로 파일을 엽니다. mode
  • os.O_CREATE: 파일이 없으면 생성합니다. 존재
  • os.O_APPEND: 파일이 존재하는 경우 파일에 데이터를 추가합니다

os.OpenFile을 사용하면 로그가 성공적으로 기록되도록 하는 데 필요한 파일 액세스 권한을 지정할 수 있습니다. 파일입니다.

위 내용은 Go에서 파일에 로그를 성공적으로 쓰는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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