golang 日志

日志规范

在这里插入图片描述

标准库

  • log库利用全局变量std来调用标准日志命令
    • 可以根据需要创建自己的日志变量
//log.go in package log

// 每种格式占据一个bit,所以可以通过|设置格式
const (
	Ldate         = 1 << iota     // the date in the local time zone: 2009/01/23
	Ltime                         // the time in the local time zone: 01:23:23
	Lmicroseconds                 // microsecond resolution: 01:23:23.123123.  assumes Ltime.
	Llongfile                     // full file name and line number: /a/b/c/d.go:23
	Lshortfile                    // final file name element and line number: d.go:23. overrides Llongfile
	LUTC                          // if Ldate or Ltime is set, use UTC rather than the local time zone
	LstdFlags     = Ldate | Ltime // initial values for the standard logger
)


// 日志变量类型
// 互斥锁保证多个goroutine的线程安全
type Logger struct {
	mu     sync.Mutex // ensures atomic writes; protects the following fields
	prefix string     // prefix to write at beginning of each line
	flag   int        // properties
	out    io.Writer  // destination for output
	buf    []byte     // for accumulating text to write
}

// 全局变量
var std = New(os.Stderr, "", LstdFlags)

// 标准日志命令是通过std调用的
func Println(v ...interface{}) {
	std.Output(2, fmt.Sprintln(v...))
}

创建自己的日志变量

var (
	Info2  *log.Logger
	Error2 *log.Logger
)

func init() {
	Info2 = log.New(os.Stdout, "[info]", log.Ldate|log.Ltime|log.Lshortfile)
	Error2 = log.New(io.MultiWriter(os.Stdout, os.Stderr, "[Error]", log.Ldate|log.Ltime|log.Lshortfile)
}

同时输出到终端和文件

file, _ := os.Create(PATH)
mw := io.MultiWriter(os.Stdout, file)
log.SetOutput(mw)

第三方库

  • 可以在引入第三方库的时候加一次封装,统一调用形式,以便后续切换第三方库
type Logger interface {
	Debug(args ...interface{})
	Info(args ...interface{})
	...
}

var std Logger 

func Setup() {
	// initialize global log instance
	std = Logger(zap.NewLogger())
}

func Info(args ...interface) {
	std.Info(args...)
}	

func Debug(args ...interface) {
	std.Info(args...)
}	

logrus库

zap库

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值