Table of Contents
ZAP provides three methods for creating Logger instances:
by calling the
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.
Write the file at the level
Just specify the
As mentioned earlier, to display the file path and line number, just add parameters
Leapcell: Best Golang application hosting, asynchronous task and Redis platform
Home Backend Development Golang Zap: Unlock the Full Potential of Logging in Go

Zap: Unlock the Full Potential of Logging in Go

Jan 28, 2025 pm 06:03 PM

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: Unlock the Full Potential of Logging in Go

Example creation

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信息")
Copy after login
Copy after login
<code>// Example 输出
{"level":"debug","msg":"这是一条DEBUG信息"}
{"level":"info","msg":"这是一条INFO信息"}</code>
Copy after login
Copy after login
<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>
Copy after login
Copy after login
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>
Copy after login
Copy after login

<<> 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
    ZAP provides two logger types:
  • and
. The difference is that you can obtain

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)
}
Copy after login
Copy after login

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

. Examples as follows: <下>
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")
}
Copy after login
<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>
Copy after login
File segmentation <文>
// 代码示例
var log *zap.Logger
log = zap.NewExample()
log, _ := zap.NewDevelopment()
log, _ := zap.NewProduction()
log.Debug("这是一条DEBUG信息")
log.Info("这是一条INFO信息")
Copy after login
Copy after login

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

After modification, the log and Debug -level logs are stored in info.log, and the ERROR -level logs are stored in the error.log file alone.
<code>// Example 输出
{"level":"debug","msg":"这是一条DEBUG信息"}
{"level":"info","msg":"这是一条INFO信息"}</code>
Copy after login
Copy after login

The console shows the color at the level

Just specify the

of the encoder.

EncodeLevel

Display file path and line number
<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>
Copy after login
Copy after login

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

Full code <完>
<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>
Copy after login
Copy after login

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)
}
Copy after login
Copy after login

Finally, recommend a best platform to deploy Golang services: Leapcell

Zap: Unlock the Full Potential of Logging in Go 1. Multi -language support

Use JavaScript, Python, GO or Rust for development.

    2. Deploy unlimited projects for free
Just pay for use -no request, no cost.

    3. Unparalleled cost benefits
Pay on demand, no idle costs.

For example: $ 25 supports 6.94 million requests, with an average response time of 60 milliseconds.
  • 4. Simplified developer experience
intuitive UI, easy settings.

Full automatic CI/CD pipeline and gitops integration.
  • Real -time indicators and log records provide operating insights.
  • 5. Easy expansion and high performance
Automatic extension to easily handle high and merger.

Zero operation expenses -just focus on construction.
  • Learn more information in the document!

Leapcell Twitter: Zap: Unlock the Full Potential of Logging in Go 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 Sections with the actual code from the input.

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!

Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

Video Face Swap

Video Face Swap

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

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

Hot Topics

Java Tutorial
1663
14
PHP Tutorial
1266
29
C# Tutorial
1239
24
Golang's Purpose: Building Efficient and Scalable Systems Golang's Purpose: Building Efficient and Scalable Systems Apr 09, 2025 pm 05:17 PM

Go language performs well in building efficient and scalable systems. Its advantages include: 1. High performance: compiled into machine code, fast running speed; 2. Concurrent programming: simplify multitasking through goroutines and channels; 3. Simplicity: concise syntax, reducing learning and maintenance costs; 4. Cross-platform: supports cross-platform compilation, easy deployment.

Golang and C  : Concurrency vs. Raw Speed Golang and C : Concurrency vs. Raw Speed Apr 21, 2025 am 12:16 AM

Golang is better than C in concurrency, while C is better than Golang in raw speed. 1) Golang achieves efficient concurrency through goroutine and channel, which is suitable for handling a large number of concurrent tasks. 2)C Through compiler optimization and standard library, it provides high performance close to hardware, suitable for applications that require extreme optimization.

Golang vs. Python: Performance and Scalability Golang vs. Python: Performance and Scalability Apr 19, 2025 am 12:18 AM

Golang is better than Python in terms of performance and scalability. 1) Golang's compilation-type characteristics and efficient concurrency model make it perform well in high concurrency scenarios. 2) Python, as an interpreted language, executes slowly, but can optimize performance through tools such as Cython.

Golang's Impact: Speed, Efficiency, and Simplicity Golang's Impact: Speed, Efficiency, and Simplicity Apr 14, 2025 am 12:11 AM

Goimpactsdevelopmentpositivelythroughspeed,efficiency,andsimplicity.1)Speed:Gocompilesquicklyandrunsefficiently,idealforlargeprojects.2)Efficiency:Itscomprehensivestandardlibraryreducesexternaldependencies,enhancingdevelopmentefficiency.3)Simplicity:

Golang vs. Python: Key Differences and Similarities Golang vs. Python: Key Differences and Similarities Apr 17, 2025 am 12:15 AM

Golang and Python each have their own advantages: Golang is suitable for high performance and concurrent programming, while Python is suitable for data science and web development. Golang is known for its concurrency model and efficient performance, while Python is known for its concise syntax and rich library ecosystem.

Golang and C  : The Trade-offs in Performance Golang and C : The Trade-offs in Performance Apr 17, 2025 am 12:18 AM

The performance differences between Golang and C are mainly reflected in memory management, compilation optimization and runtime efficiency. 1) Golang's garbage collection mechanism is convenient but may affect performance, 2) C's manual memory management and compiler optimization are more efficient in recursive computing.

The Performance Race: Golang vs. C The Performance Race: Golang vs. C Apr 16, 2025 am 12:07 AM

Golang and C each have their own advantages in performance competitions: 1) Golang is suitable for high concurrency and rapid development, and 2) C provides higher performance and fine-grained control. The selection should be based on project requirements and team technology stack.

C   and Golang: When Performance is Crucial C and Golang: When Performance is Crucial Apr 13, 2025 am 12:11 AM

C is more suitable for scenarios where direct control of hardware resources and high performance optimization is required, while Golang is more suitable for scenarios where rapid development and high concurrency processing are required. 1.C's advantage lies in its close to hardware characteristics and high optimization capabilities, which are suitable for high-performance needs such as game development. 2.Golang's advantage lies in its concise syntax and natural concurrency support, which is suitable for high concurrency service development.

See all articles