Golang ialah bahasa pengaturcaraan yang sangat popular yang sering digunakan untuk membangunkan aplikasi bahagian pelayan berprestasi tinggi dan boleh dipercayai. Dalam pembangunan sebenar, pembalakan adalah fungsi yang sangat penting, digunakan untuk merekodkan pelbagai maklumat status, maklumat pengecualian, log ralat, dan lain-lain semasa program berjalan. Menggunakan log, anda boleh menyahpepijat dan menyelesaikan masalah dengan mudah. Artikel ini akan memperkenalkan perpustakaan pengelogan yang biasa digunakan di Golang dan memberikan contoh kod khusus.
pakej log ialah perpustakaan pengelogan yang disediakan oleh bahasa Golang itu sendiri. Ia menyediakan fungsi pengelogan standard, dan pengelogan boleh dilaksanakan dengan mudah melalui API mudah. Ia mempunyai ciri-ciri berikut:
contoh yang menunjukkan cara menggunakan pakej ini untuk logHere pengelogan Pengelogan:
package main import ( "log" "os" ) func main() { // 日志记录到文件 f, err := os.OpenFile("test.log", os.O_APPEND|os.O_CREATE|os.O_WRONLY, 0644) if err != nil { log.Fatal(err) } defer f.Close() log.SetPrefix("[TEST]") log.SetOutput(f) log.Println("Test log message") }
Kod di atas menunjukkan cara untuk log ke fail bernama test.log dan menambah teg awalan "[TEST]". Hanya panggil log untuk mengeluarkan maklumat yang berkaitan. Pakej
zap ialah perpustakaan pengelogan berasaskan berstruktur dengan prestasi cemerlang dan kemudahan penggunaan. Ia menyediakan keupayaan log masuk dan pertanyaan log yang cekap serta mempunyai ciri-ciri berikut:
Berikut ialah contoh yang menunjukkan cara menggunakan perpustakaan zap untuk pengelogan:
package main import ( "go.uber.org/zap" ) func main() { logger, _ := zap.NewProduction() logger.Info("This is an info message", zap.String("key1", "value1"), zap.Int("key2", 100)) logger.Error("This is an error message", zap.Error(errors.New("error"))) }
Kod di atas menunjukkan cara menggunakan perpustakaan zap untuk pengelogan. Mula-mula buat contoh Logger baharu dengan memanggil fungsi zap.NewProduction() dan kemudian gunakan fungsi logger.Info() dan logger.Error() untuk pengelogan. Mereka semua boleh menerima bilangan parameter nilai kunci yang berbeza-beza, yang boleh ditetapkan melalui fungsi seperti zap.String().
logrus ialah perpustakaan pembalakan berstruktur yang sangat fleksibel yang menyediakan gaya panggilan fungsi yang serupa dengan pakej pembalakan dalam Python dan mempunyai ciri-ciri berikut:
Berikut ialah contoh untuk menunjukkan cara menggunakan Logrus Logging:
package main import ( "github.com/sirupsen/logrus" ) func main() { log := logrus.New() log.SetLevel(logrus.DebugLevel) log.SetFormatter(&logrus.JSONFormatter{}) log.WithFields(logrus.Fields{ "animal": "walrus", "size": 10, "weight": 100, }).Info("A group of walrus emerges from the ocean") }
Kod di atas menunjukkan cara menggunakan logrus untuk pengelogan, dengan tahap log ditetapkan kepada Nyahpepijat dan format output ditetapkan kepada JSON. Adalah disyorkan untuk mentakrifkan contoh logrus.Logger global dalam kod dan melakukan pengelogan melalui fungsi logrus.WithFields().
Ringkasan
Di atas memperkenalkan perpustakaan log yang biasa digunakan di Golang, termasuk pakej log, pakej zap dan pakej logrus. Setiap perpustakaan ini mempunyai beberapa ciri dan kelebihan, dan pilihan khusus perlu ditentukan berdasarkan keperluan projek sebenar. Dalam pembangunan sebenar, pengelogan adalah fungsi penting Ia boleh merekodkan maklumat status program dengan mudah dan membantu kami nyahpepijat dan menyelesaikan masalah.
Atas ialah kandungan terperinci Perpustakaan pembalakan Golang yang disyorkan dan biasa digunakan. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!