Go: Memanfaatkan io.Writer Interface untuk MongoDB Logging
Persoalan timbul sama ada mungkin untuk mewujudkan logger yang menghasilkan output terus ke pangkalan data, khususnya dalam konteks MongoDB. Lebih tepat lagi, bolehkah antara muka io.Writer dilaksanakan dan dibekalkan sebagai parameter awal untuk log.New()? Antara muka ini akan membolehkan pengelogan terus ke pangkalan data MongoDB dengan berkesan.
Pendekatan konvensional adalah untuk mencipta fungsi pengelogan pangkalan data tersuai. Walau bagaimanapun, ia patut diterokai jika terdapat pilihan sedia ada dalam bahasa Go yang menyediakan fungsi ini.
Dalam konteks MongoDB, mgo.v2 ialah perpustakaan utama yang digunakan untuk pengendalian pangkalan data. Walau bagaimanapun, ia tidak mempunyai antara muka io.Writer selain daripada GridFS, yang mempunyai tujuan yang berbeza.
Walaupun begitu, pelaksanaan io.Writer untuk pengelogan MongoDB boleh dilaksanakan. Ini didasarkan pada jaminan oleh log.Jenis Logger bahawa setiap mesej log dihantar ke io.Writer yang ditetapkan dengan seruan Writer.Write() tunggal.
Melaksanakan jenis yang mematuhi io.Writer, di mana kaedah Write()nya mencipta dokumen yang mengandungi muatan kepingan bait dan mengekalkannya dalam MongoDB, sudah memadai.
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 }
Dengan memanfaatkan pelaksanaan ini:
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.")
Adalah penting untuk ambil perhatian bahawa mesej log biasanya diakhiri dengan baris baharu, yang dilampirkan dengan log.Logger walaupun dalam ketiadaannya daripada mesej sebenar. Sekiranya anda lebih suka meninggalkan baris baharu yang ditamatkan ini, cuma potong:
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) }
Atas ialah kandungan terperinci Bolehkah `log.New()` Go menggunakan `io.Writer` untuk log terus ke MongoDB?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!