GO Language High Performance Library ZAP Detailed Explanation and Application
This article explores the high -performance GO log library ZAP developed by Uber, covering its characteristics, usage methods and advanced applications, such as log file division and level output. ZAP is famous for its speed and structured log output. The performance is better than similar libraries and even surpass the standard library.
github address: https://www.php.cn/link/26ac49243aa3065a10ca1796c2d1e57b
ZAP provides three methods for creating Logger instances:
, and zap.NewProduction()
. The difference is that they record the details of the information, and the parameter type is limited to the string. zap.NewDevelopment()
zap.Example()
// 代码示例 var log *zap.Logger log = zap.NewExample() log, _ := zap.NewDevelopment() log, _ := zap.NewProduction() log.Debug("这是一条DEBUG信息") log.Info("这是一条INFO信息")
<code>// Example 输出 {"level":"debug","msg":"这是一条DEBUG信息"} {"level":"info","msg":"这是一条INFO信息"}</code>
<code>// Development 输出 2025-01-28T00:00:00.000+0800 DEBUG development/main.go:7 这是一条DEBUG信息 2025-01-28T00:00:00.000+0800 INFO development/main.go:8 这是一条INFO信息</code>Three creation methods comparison:
<code>// Production 输出 {"level":"info","ts":1737907200.0000000,"caller":"production/main.go:8","msg":"这是一条INFO信息"} {"level":"info","ts":1737907200.0000000,"caller":"production/main.go:9","msg":"这是一条包含字段的INFO信息","region":["us-west"],"id":2}</code>
and
- Using JSON format output,
- use line format output.
Example
Production
Development Development
- Start printing stack information from the warning level, for tracking.
Always printed package/file/line number (method).
- Add additional fields as the JSON string to the tail.
- Printing the name of the uppercase letter.
- Use millisecond -level ISO8601 format to print timestamp.
-
Production
No record of debugging level news. -
For errors and panic records, the files in the stack will be tracked, but the warning level will not.
- Always add the file information of the caller.
- Printing date with a time stamp format.
- Print the name of the lowercase letter.
- Format output
and
by calling the
method of the main logger, and use it to record the statement in the Printf format:
*zap.Logger
*zap.SugaredLogger
Write the file
.Sugar()
By default, log output to the application console. To facilitate the inquiries, the log can be written into the file. At this time, the three methods of creating instances mentioned earlier cannot be used, but SugaredLogger
.
var sugarLogger *zap.SugaredLogger func InitLogger() { logger, _ := zap.NewProduction() sugarLogger = logger.Sugar() } func main() { InitLogger() defer sugarLogger.Sync() sugarLogger.Errorf("获取URL %s 失败:错误 = %s", url, err) }
At the same time, output to the console and file
zap.New()
If you need to output to the console and file at the same time, you only need to modify
package main import ( "go.uber.org/zap" "go.uber.org/zap/zapcore" "os" ) var log *zap.Logger func main() { writeSyncer, _ := os.Create("./info.log") // 日志文件存储目录 encoderConfig := zap.NewProductionEncoderConfig() // 指定时间格式 encoderConfig.EncodeTime = zapcore.ISO8601TimeEncoder encoderConfig.EncodeLevel = zapcore.CapitalLevelEncoder encoder := zapcore.NewConsoleEncoder(encoderConfig) // 获取编码器,NewJSONEncoder() 输出JSON格式,NewConsoleEncoder() 输出纯文本格式 core := zapcore.NewCore(encoder, writeSyncer, zapcore.DebugLevel) // 第三及后续参数是写入文件的日志级别。ErrorLevel模式下,只记录错误级别的日志。 log = zap.New(core,zap.AddCaller()) // AddCaller() 用于显示文件名和行号。 log.Info("hello world") log.Error("hello world") }
<code>// 日志文件输出结果: 2025-01-28T00:00:00.000+0800 INFO geth/main.go:18 hello world 2025-01-28T00:00:00.000+0800 ERROR geth/main.go:19 hello world</code>File segmentation
Log files will become larger and larger over time. To avoid occupying a large number of disk space, log files are needed according to specific conditions. ZAP itself does not provide file segmentation function, but you can use the Lumberjack package recommended by ZAP to achieve it.
// 代码示例 var log *zap.Logger log = zap.NewExample() log, _ := zap.NewDevelopment() log, _ := zap.NewProduction() log.Debug("这是一条DEBUG信息") log.Info("这是一条INFO信息")
Write the file at the level
In order to facilitate the inquiries of managers, the logs below the error level are usually written into info.log. The logs of error level and above are written into the error.log file. You only need to modify the third parameter of the method, and then divide the file to the info and error. Examples as follows:
zapcore.NewCore
<code>// Example 输出 {"level":"debug","msg":"这是一条DEBUG信息"} {"level":"info","msg":"这是一条INFO信息"}</code>
The console shows the color at the level
Just specify the
of the encoder.
EncodeLevel
<code>// Development 输出 2025-01-28T00:00:00.000+0800 DEBUG development/main.go:7 这是一条DEBUG信息 2025-01-28T00:00:00.000+0800 INFO development/main.go:8 这是一条INFO信息</code>
As mentioned earlier, to display the file path and line number, just add parameters
to the method. If you want to display the complete path, you need to specify in the encoder configuration. zap.New
zap.AddCaller()
<code>// Production 输出 {"level":"info","ts":1737907200.0000000,"caller":"production/main.go:8","msg":"这是一条INFO信息"} {"level":"info","ts":1737907200.0000000,"caller":"production/main.go:9","msg":"这是一条包含字段的INFO信息","region":["us-west"],"id":2}</code>
Leapcell: Best Golang application hosting, asynchronous task and Redis platform
var sugarLogger *zap.SugaredLogger func InitLogger() { logger, _ := zap.NewProduction() sugarLogger = logger.Sugar() } func main() { InitLogger() defer sugarLogger.Sync() sugarLogger.Errorf("获取URL %s 失败:错误 = %s", url, err) }
Finally, recommend a best platform to deploy Golang services: Leapcell
1. Multi -language support
Use JavaScript, Python, GO or Rust for development.
- 2. Deploy unlimited projects for free
- 3. Unparalleled cost benefits
For example: $ 25 supports 6.94 million requests, with an average response time of 60 milliseconds.
- 4. Simplified developer experience
Full automatic CI/CD pipeline and gitops integration.
- Real -time indicators and log records provide operating insights.
- 5. Easy expansion and high performance
Zero operation expenses -just focus on construction.
- Learn more information in the document!
Leapcell Twitter: https://www.php.cn/link/7884effb9452a6d7a79499EF854AFD
This Revied Output Maintains The Original Meaning and Image Placement While Significantly ALTERING AND Structure for Originality. Remember to re Place the
The above is the detailed content of Zap: Unlock the Full Potential of Logging in Go. For more information, please follow other related articles on the PHP Chinese website!

Go's "strings" package provides rich features to make string operation efficient and simple. 1) Use strings.Contains() to check substrings. 2) strings.Split() can be used to parse data, but it should be used with caution to avoid performance problems. 3) strings.Join() is suitable for formatting strings, but for small datasets, looping = is more efficient. 4) For large strings, it is more efficient to build strings using strings.Builder.

Go uses the "strings" package for string operations. 1) Use strings.Join function to splice strings. 2) Use the strings.Contains function to find substrings. 3) Use the strings.Replace function to replace strings. These functions are efficient and easy to use and are suitable for various string processing tasks.

ThebytespackageinGoisessentialforefficientbyteslicemanipulation,offeringfunctionslikeContains,Index,andReplaceforsearchingandmodifyingbinarydata.Itenhancesperformanceandcodereadability,makingitavitaltoolforhandlingbinarydata,networkprotocols,andfileI

Go uses the "encoding/binary" package for binary encoding and decoding. 1) This package provides binary.Write and binary.Read functions for writing and reading data. 2) Pay attention to choosing the correct endian (such as BigEndian or LittleEndian). 3) Data alignment and error handling are also key to ensure the correctness and performance of the data.

The"bytes"packageinGooffersefficientfunctionsformanipulatingbyteslices.1)Usebytes.Joinforconcatenatingslices,2)bytes.Bufferforincrementalwriting,3)bytes.Indexorbytes.IndexByteforsearching,4)bytes.Readerforreadinginchunks,and5)bytes.SplitNor

Theencoding/binarypackageinGoiseffectiveforoptimizingbinaryoperationsduetoitssupportforendiannessandefficientdatahandling.Toenhanceperformance:1)Usebinary.NativeEndianfornativeendiannesstoavoidbyteswapping.2)BatchReadandWriteoperationstoreduceI/Oover

Go's bytes package is mainly used to efficiently process byte slices. 1) Using bytes.Buffer can efficiently perform string splicing to avoid unnecessary memory allocation. 2) The bytes.Equal function is used to quickly compare byte slices. 3) The bytes.Index, bytes.Split and bytes.ReplaceAll functions can be used to search and manipulate byte slices, but performance issues need to be paid attention to.

The byte package provides a variety of functions to efficiently process byte slices. 1) Use bytes.Contains to check the byte sequence. 2) Use bytes.Split to split byte slices. 3) Replace the byte sequence bytes.Replace. 4) Use bytes.Join to connect multiple byte slices. 5) Use bytes.Buffer to build data. 6) Combined bytes.Map for error processing and data verification.


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

SublimeText3 Linux new version
SublimeText3 Linux latest version

ZendStudio 13.5.1 Mac
Powerful PHP integrated development environment

SublimeText3 English version
Recommended: Win version, supports code prompts!

Safe Exam Browser
Safe Exam Browser is a secure browser environment for taking online exams securely. This software turns any computer into a secure workstation. It controls access to any utility and prevents students from using unauthorized resources.
