Go 언어 학습 노트 8:log의 사용, 로그 파일과 mongodb로 출력
1. 파일에 로그 출력
func CreateDir(dir string) (bool, error) {
_, err := os.Stat(dir)
if err == nil {
//directory exists
return true, nil
}
err2 := os.MkdirAll(dir, 0755)
if err2 != nil {
return false, err2
}
return true, nil
}
func main() {
res2, err := fileManager.CreateDir("/LOG/PATH") //
if res2 == false {
panic(err)
}
file, _ := os.OpenFile("/LOG/PATH/error.log", os.O_RDWR|os.O_CREATE|os.O_APPEND, 0666) // ,
defer file.Close()
log.SetOutput(file) //
log.SetPrefix("[Error]") //
log.SetFlags(log.Llongfile | log.Ldate | log.Ltime) //
log.Println("Hi file")
}
2. 로그를 몬고로 출력
Write 메서드를 실례화해야 합니다.
type MongoWriter struct {
session *mgo.Session
}
func (mw *MongoWriter) Write(p []byte) (n int, err error) {
c := mw.session.DB("db_seetacloud").C("t_system_errors_log")
err = c.Insert(bson.M{ // mongo
"datetime": time.Now().Format("2006-01-02 15:04:05"),
"message": string(p),
"channel":"Golang",
})
if err != nil {
return
}
return len(p), nil
}
func main() {
session :=
mw := &MongoWriter{session}
log.SetOutput(mw)
log.SetPrefix("[Error]")
log.SetFlags(log.Llongfile | log.Ldate | log.Ltime)
log.Println("Hi mongo")
}
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
다양한 언어의 JSONJSON은 Javascript 표기법을 사용하여 데이터 구조를 레이아웃하는 데이터 형식입니다. 그러나 Javascript가 코드에서 이러한 구조를 나타낼 수 있는 유일한 언어는 아닙니다. 저는 일반적으로 '객체'{}...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.