>백엔드 개발 >Golang >Go의 `log.New()`는 `io.Writer`를 사용하여 MongoDB에 직접 로그인할 수 있나요?

Go의 `log.New()`는 `io.Writer`를 사용하여 MongoDB에 직접 로그인할 수 있나요?

Susan Sarandon
Susan Sarandon원래의
2024-12-05 13:11:09391검색

Can Go's `log.New()` use an `io.Writer` to directly log to MongoDB?

Go: MongoDB 로깅을 위한 io.Writer 인터페이스 활용

다음에 직접 출력하는 로거를 설정하는 것이 가능한지 의문이 생깁니다. 데이터베이스, 특히 MongoDB의 컨텍스트 내에서. 보다 정확하게는 io.Writer 인터페이스를 구현하고 log.New()의 초기 매개변수로 제공할 수 있습니까? 이 인터페이스는 MongoDB 데이터베이스에 대한 직접 로깅을 효과적으로 활성화합니다.

일반적인 접근 방식은 사용자 정의 데이터베이스 로깅 기능을 만드는 것입니다. 하지만 Go 언어 내에 이 기능을 제공하는 기존 옵션이 있는지 살펴볼 가치가 있습니다.

MongoDB의 맥락에서 mgo.v2는 데이터베이스 처리에 사용되는 기본 라이브러리입니다. 그러나 뚜렷한 목적을 제공하는 GridFS 외에 io.Writer 인터페이스가 부족합니다.

이에도 불구하고 MongoDB 로깅을 위해 io.Writer를 구현하는 것은 가능합니다. 이는 단일 Writer.Write() 호출을 통해 각 로그 메시지가 지정된 io.Writer에 전달된다는 log.Logger 유형의 보장을 전제로 합니다.

io.Writer를 준수하는 유형 구현, Write() 메소드는 바이트 슬라이스의 페이로드를 포함하는 문서를 생성하고 이를 MongoDB에 유지합니다. 충분합니다.

type MongoWriter struct {
    sess *mgo.Session
}

func (mw *MongoWriter) Write(p []byte) (n int, err error) {
    c := mw.sess.DB("").C("log")
    err = c.Insert(bson.M{
        "created": time.Now(),
        "msg":     string(p),
    })
    if err != nil {
        return
    }
    return len(p), nil
}

이 구현을 활용하면 다음과 같습니다.

sess := ... // Obtain a MongoDB session

mw := &MongoWriter{sess}
log.SetOutput(mw)

// The default Logger of the log package now utilizes our MongoWriter.
// Generate a log message for insertion into MongoDB:
log.Println("I'm the inaugural log message.")
log.Println("I'm multi-line,\nbut remain within a single log message.")

로그 메시지는 일반적으로 새 줄로 끝나며, 줄 바꿈이 없는 경우에도 log.Logger에 의해 추가된다는 점에 유의하는 것이 중요합니다. 실제 메시지에서. 이 종료 개행 문자를 생략하려면 간단히 잘라내세요.

func (mw *MongoWriter) Write(p []byte) (n int, err error) {
    origLen := len(p)
    if len(p) > 0 && p[len(p)-1] == '\n' {
        p = p[:len(p)-1] // Cut terminating newline
    }

    c := mw.sess.DB("").C("log")

    // ... the rest remains unchanged

    return origLen, nil // Original length must be returned (due to p being resliced)
}

위 내용은 Go의 `log.New()`는 `io.Writer`를 사용하여 MongoDB에 직접 로그인할 수 있나요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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