Rumah >pembangunan bahagian belakang >Golang >Perpustakaan pembalakan Golang yang disyorkan dan biasa digunakan

Perpustakaan pembalakan Golang yang disyorkan dan biasa digunakan

WBOY
WBOYasal
2024-01-16 10:16:051408semak imbas

Perpustakaan pembalakan Golang yang disyorkan dan biasa digunakan

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.

  1. pakej log

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:

  • Menyokong pengelogan berbilang peringkat
  • Menyokong teg awalan
  • Menyokong pemformatan tarikh dan masa
  • Menyokong output kepada aliran keluaran yang berbeza

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

  1. zap

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:

  • Pantas (prestasi tinggi)
  • Taip sepenuhnya selamat
  • API Intuitif
  • Tetapan tahap log automatik
  • Dengan pilihan, templat yang kaya dengan sintaks
  • boleh diperluaskan
  • menyokong diedarkan

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().

  1. pakej logrus

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:

  • Dengan tahap log tersuai
  • Menyokong pemformatan log
  • log keluaran dalam JSON, Teks, Logstash dan format lain
  • Boleh mengembangkan format log, kaedah output dengan mudah dan disepadukan dengan sistem pengurusan log lain

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!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn