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