Ralat Terlalu Banyak Fail Terbuka dalam MongoDB dengan MGO
Apabila menjalankan pelayan MongoDB yang ditulis dalam Go menggunakan MGO, pengguna mungkin menghadapi ralat berikut dalam log:
Accept error: accept tcp [::]:80: accept4: too many open files;
Ralat ini menunjukkan bahawa sistem telah mencapai bilangan maksimum buka fail.
Punca
Isu timbul apabila sambungan ke pelayan MongoDB tidak ditutup dengan betul. Setiap permintaan kepada pelayan biasanya membuka sambungan, dan jika sambungan tidak ditutup selepas digunakan, ia terkumpul, akhirnya mencapai had maksimum.
Penyelesaian
1. Tutup Sambungan MongoDB:
Untuk menyelesaikan isu ini, adalah penting untuk menutup sambungan MongoDB dengan segera selepas digunakan. Pendekatan yang disyorkan ialah:
2. Sahkan Jenis Sesi:
Pastikan sesi yang disimpan adalah daripada jenis mgo.Session dan bukan mgo.Database. Ini penting kerana jenis mgo.Session mengendalikan pengurusan sambungan.
3. Semak Ralat:
Adalah penting untuk menyemak ralat apabila berinteraksi dengan MongoDB. Jika ralat berlaku, kendalikan ralat dengan bijak (cth., log atau cetak), kerana pengabaian ralat boleh membawa kepada tingkah laku yang tidak konsisten.
4. Contoh Kod:
Berikut ialah versi pembetulan kod yang merangkumi pengurusan sesi yang betul:
var session *mgo.Session func init() { var err error if session, err = mgo.Dial("localhost"); err != nil { log.Fatal(err) } } func someHandler(w http.ResponseWriter, r *http.Request) { sess := session.Copy() defer sess.Close() // Must close! c := sess.DB("mapdb").C("tiles") // Do something with the collection, e.g. var result bson.M if err := c.FindId("someTileID").One(&result); err != nil { // Handle error, e.g.: log.Printf("Tile with ID not found: %v, err %v", "someTileID", err) http.NotFound(w, r) return } // Do something with result }
Soalan Berkaitan
Atas ialah kandungan terperinci Bagaimana untuk Membetulkan Ralat 'Terlalu Banyak Fail Terbuka' dalam MongoDB dengan MGO dalam Go?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!