Go语言log库学习

文章目录

日志记录

log库:https://go-zh.org/pkg/log/

syslog:https://go-zh.org/pkg/log/syslog/

  1. 基本的日志功能 :支持日志消息的输出,包括通过log.Printlog.Printflog.Println等函数记录普通日志,以及通过log.Fatallog.Fatalflog.Fatallnlog.Paniclog.Panicflog.Panicln等函数在记录日志后执行特定操作(如程序终止或panic)。
  2. 日志输出位置 :默认情况下,log包的日志输出位置是标准错误输出(stderr)。但可以通过log.SetOutput函数将日志输出重定向到其他位置,如文件或自定义的日志处理器。
  3. 日志格式和前缀 :支持自定义日志消息的前缀和时间格式。通过log.SetPrefix函数可以设置日志消息的前缀,通过log.SetFlags函数可以设置时间格式,如日期、时间、微秒级时间、文件名和行号等。
  4. 并发安全log包本身是并发安全的,可以在多个goroutine中安全地使用。
go 复制代码
func main() {  
    file, err := os.OpenFile("app.log", os.O_CREATE|os.O_WRONLY|os.O_APPEND, 0666)  
    if err != nil {  
        log.Fatal(err)  
    }  
    defer file.Close()  
    // 输出到文件  
    log.SetOutput(file)  
    log.Println("This is a log message written to a file")  
    // 自定义格式
    log.SetPrefix("INFO: ")  
    log.SetFlags(log.Ldate | log.Ltime | log.Lshortfile)  
    log.Println("This is a log message with custom prefix and flags")  
}
go 复制代码
// 不支持同时输出到文件且输出到控制台
// 所以可以这样做:
package main

import (
	"log"
	"os"
)

// 测试log同时写入控制台和文件

func multiLogger(fileLogger, stdLogger *log.Logger, msg string) {
	fileLogger.Println(msg)
	stdLogger.Println(msg)
}

func main() {
	logFile, _ := os.OpenFile("test.log", os.O_CREATE|os.O_WRONLY|os.O_APPEND, 0666)
	defer logFile.Close()

	// 创建一个新的logger实例,用于向文件写入日志
	fileLogger := log.New(logFile, "FILE: ", log.Ldate|log.Ltime|log.Lshortfile)

	// 使用标准库logger作为控制台输出
	consoleLogger := log.New(os.Stdout, "CONSOLE: ", log.Ldate|log.Ltime|log.Lshortfile)

	// 输出
	var msg string = "测试log同时写入控制台和文件"
	multiLogger(fileLogger, consoleLogger, msg)
}

Testing

相关推荐
岁岁岁平安10 分钟前
spring学习(spring-DI(字符串或对象引用注入、集合注入)(XML配置))
java·学习·spring·依赖注入·集合注入·基本数据类型注入·引用数据类型注入
武昌库里写JAVA14 分钟前
Java成长之路(一)--SpringBoot基础学习--SpringBoot代码测试
java·开发语言·spring boot·学习·课程设计
qq_5895681019 分钟前
数据可视化echarts学习笔记
学习·信息可视化·echarts
ZSYP-S1 小时前
Day 15:Spring 框架基础
java·开发语言·数据结构·后端·spring
yuanbenshidiaos1 小时前
c++------------------函数
开发语言·c++
程序员_三木1 小时前
Three.js入门-Raycaster鼠标拾取详解与应用
开发语言·javascript·计算机外设·webgl·three.js
兔C1 小时前
微信小程序的轮播图学习报告
学习·微信小程序·小程序
是小崔啊1 小时前
开源轮子 - EasyExcel01(核心api)
java·开发语言·开源·excel·阿里巴巴
海海不掉头发1 小时前
苍穹外卖-day05redis 缓存的学习
学习·缓存
tianmu_sama1 小时前
[Effective C++]条款38-39 复合和private继承
开发语言·c++