Go日志组件Zap的基本使用

文章目录

  • [1.Zap sugar输出](#1.Zap sugar输出)
  • [2. Zap 文件输出](#2. Zap 文件输出)

1.Zap sugar输出

go 复制代码
package main

import (
	"go.uber.org/zap" // 引入 zap 包
	"time"            // 引入 time 包
)

func main() {
	logger, _ := zap.NewProduction() // 创建生产环境下的 Logger 实例
	//logger, _ = zap.NewDevelopment() // 创建测试环境下的 Logger 实例
	defer logger.Sync() // 延迟关闭 Logger 并刷新缓冲区

	url := "https://imooc.com" // 定义 URL
	sugar := logger.Sugar()    // 创建一个 Sugar Logger

	sugar.Infow("failed to fetch URL",
		// 结构化上下文作为松散类型的键值对
		"url", url, // URL 键值对
		"attempt", 3, // 尝试次数键值对
		"backoff", time.Second, // 退避时长键值对
	)

	sugar.Infof("Failed to fetch URL: %s", url) // 格式化记录错误信息
}

2. Zap 文件输出

go 复制代码
package main

import (
	"go.uber.org/zap" // 引入 zap 包
	"time"            // 引入 time 包
)

// NewLogger 返回一个 zap.Logger 实例和可能的错误
func NewLogger() (*zap.Logger, error) {
	// 创建一个生产配置的 Logger 配置
	cfg := zap.NewProductionConfig()
	// 设置输出路径
	cfg.OutputPaths = []string{
		"./myproject.log", // 输出到 myproject.log 文件
		"stderr",          // 输出到标准错误
		"stdout",          // 输出到标准输出
	}
	// 根据配置构建 Logger
	return cfg.Build()
}

func main() {
	// 初始化 logger
	logger, err := NewLogger()
	if err != nil {
		panic(err) // 如果初始化失败,则抛出错误
		//panic("初始化logger失败")
	}
	su := logger.Sugar() // 创建一个 sugar logger
	defer su.Sync()      // 在退出前同步日志

	url := "https://imooc.com" // 设置 URL
	// 记录日志信息
	su.Info("failed to fetch URL",
		// 结构化上下文作为强类型的 Field 值
		zap.String("url", url),               // 记录 URL 字段
		zap.Int("attempt", 3),                // 记录尝试次数字段
		zap.Duration("backoff", time.Second), // 记录退避时长字段
	)
}
相关推荐
geovindu4 小时前
go: Mediator Pattern
设计模式·golang·中介者模式
MATLAB代码顾问6 小时前
5大智能算法优化标准测试函数对比(Python实现)
开发语言·python
万粉变现经纪人8 小时前
如何解决 pip install llama-cpp-python 报错 未安装 CMake/Ninja 或 CPU 不支持 AVX 问题
开发语言·python·开源·aigc·pip·ai写作·llama
小码哥_常8 小时前
Spring Boot:别再重复造轮子,这些内置功能香麻了
后端
清风明月一壶酒8 小时前
OpenClaw自动处理Word文档全流程
开发语言·c#·word
其实防守也摸鱼8 小时前
CTF密码学综合教学指南--第五章
开发语言·网络·笔记·python·安全·网络安全·密码学
皮皮林5518 小时前
OpenFeign 首次调用卡 3 秒?八年老开发扒透 5 个坑,实战优化到 100ms!
后端
小郑加油9 小时前
python学习Day12:pandas安装与实际运用
开发语言·python·学习
AC赳赳老秦9 小时前
投标合规提效:用 OpenClaw 实现标书 / 合同自动审核、关键词校验、格式优化,降低废标风险
开发语言·前端·python·eclipse·emacs·deepseek·openclaw
KuaCpp10 小时前
C++面向对象(速过复习版)
开发语言·c++