【go】log包讲解与案例

Go 中的 log 包

log 包是 Go 语言标准库中的日志库,用于记录程序的运行信息。它提供了简单的日志记录功能,适合开发阶段的调试和生产环境的基本日志输出需求。

log 包的核心功能

  • 输出日志信息到标准输出或文件。
  • 提供多种日志级别(通过扩展,如 log.Logger)。
  • 支持自定义日志前缀和时间戳格式。
  • 易于集成到更复杂的日志系统中。

log 包的常用函数

  • log.Print:输出日志信息(类似 fmt.Print)。
  • log.Println:输出日志信息并在末尾添加换行符(类似 fmt.Println)。
  • log.Printf:按指定格式输出日志信息(类似 fmt.Printf)。
  • log.Fatal:输出日志信息后调用 os.Exit(1) 终止程序。
  • log.Panic:输出日志信息后引发 panic。

示例代码:

package mainimport "log"func main() {log.Print("这是一条普通日志")log.Println("这是一条带换行的日志")log.Printf("这是一条格式化日志:变量值为 %d", 42)// Fatal 和 Panic 示例(请注释其中之一以避免程序中断)// log.Fatal("这是一条致命日志,程序将在日志后退出")// log.Panic("这是一条会引发 panic 的日志")
}

输出示例:

2024/12/09 12:00:00 这是一条普通日志
2024/12/09 12:00:00 这是一条带换行的日志
2024/12/09 12:00:00 这是一条格式化日志:变量值为 42

自定义日志功能

log 包允许创建自定义的 Logger 实例,可以指定输出目标、前缀和日志标志。

  • log.New:创建新的 Logger 实例。
  • log.Flags:设置日志格式标志(如日期、时间、微秒、文件行号)。
  • log.SetOutput:更改日志输出位置(如文件)。

示例代码:自定义日志前缀和输出文件

package mainimport ("log""os"
)func main() {// 打开日志文件file, err := os.OpenFile("app.log", os.O_CREATE|os.O_WRONLY|os.O_APPEND, 0666)if err != nil {log.Fatalf("无法打开日志文件: %v", err)}defer file.Close()// 创建自定义 Loggerlogger := log.New(file, "INFO: ", log.Ldate|log.Ltime|log.Lshortfile)// 记录日志logger.Println("应用程序启动")logger.Printf("当前状态:%s", "运行中")// 错误日志示例logger.SetPrefix("ERROR: ")logger.Println("发生错误,无法连接数据库")
}

输出日志文件内容:

INFO: 2024/12/09 12:00:00 main.go:20: 应用程序启动
INFO: 2024/12/09 12:00:00 main.go:21: 当前状态:运行中
ERROR: 2024/12/09 12:00:00 main.go:24: 发生错误,无法连接数据库

企业级使用案例

在企业应用中,log 包通常与其他工具(如多模块日志记录、远程日志收集等)结合使用。以下示例展示了一个基于 log 包的多级日志记录器:

示例代码:多级日志记录

package mainimport ("log""os"
)// Logger 定义多级日志记录器
type Logger struct {Info  *log.LoggerError *log.Logger
}func NewLogger(infoFile, errorFile string) (*Logger, error) {// 打开日志文件infoLog, err := os.OpenFile(infoFile, os.O_CREATE|os.O_WRONLY|os.O_APPEND, 0666)if err != nil {return nil, err}errorLog, err := os.OpenFile(errorFile, os.O_CREATE|os.O_WRONLY|os.O_APPEND, 0666)if err != nil {infoLog.Close()return nil, err}return &Logger{Info:  log.New(infoLog, "INFO: ", log.Ldate|log.Ltime|log.Lshortfile),Error: log.New(errorLog, "ERROR: ", log.Ldate|log.Ltime|log.Lshortfile),}, nil
}func main() {logger, err := NewLogger("info.log", "error.log")if err != nil {log.Fatalf("无法创建日志记录器: %v", err)}logger.Info.Println("服务启动成功")logger.Error.Println("数据库连接失败:超时")
}

输出示例:

  • info.log 文件:
INFO: 2024/12/09 12:00:00 main.go:30: 服务启动成功
  • error.log 文件:
ERROR: 2024/12/09 12:00:00 main.go:31: 数据库连接失败:超时

总结

  • log 包提供了基础的日志记录功能,适合简单的日志需求。
  • 通过 log.New 和 log.SetOutput,可以实现更灵活的日志记录方式。
  • 在企业中,通常需要将 log 包与日志管理系统(如 ELK、Fluentd)结合使用,实现更高级的日志处理。

代码案例

package _caseimport ("log""os"
)func init() {log.SetFlags(log.Ldate | log.Ltime | log.Llongfile)log.SetOutput(os.Stderr)
}func LogCase() {//log.SetFlags(log.Ldate | log.Ltime | log.Lshortfile)log.Println("带有日期、时间和文件信息的日志:")a, b := -1, -11_, err := sum(a, b)if err != nil {log.Println(err)log.Fatal(err) // fatal 打印日志后会导致程序的退出}
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/888992.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

回归任务与分类任务应用及评价指标

能源系统中的回归任务与分类任务应用及评价指标 一、回归任务应用1.1 能源系统中的回归任务应用1.1.1 能源消耗预测1.1.2 负荷预测1.1.3 电池健康状态估计(SOH预测)1.1.4 太阳能发电量预测1.1.5 风能发电量预测 1.2 回归任务中的评价指标1.2.1 RMSE&…

在Ubuntu上使用IntelliJ IDEA:开启你的Java开发之旅!

你好,年轻的学徒!🧑‍💻 是时候踏上进入Java开发世界的史诗之旅了,我们的得力助手将是强大的IntelliJ IDEA。准备好了吗?出发吧! 在我们开始之前,我们需要下载这个工具。但是&#…

TCP/IP 协议栈高效可靠的数据传输机制——以 Linux 4.19 内核为例

TCP/IP 协议栈是一种非常成熟且广泛使用的网络通信框架,它将复杂的网络通信任务分成多个层次,从而简化设计,使每一层的功能更加清晰和独立。在经典的 TCP/IP 协议栈中,常见的分层为链路层、网络层、传输层和应用层。本文将对每一层的基本功能进行描述,并列出对应于 Linux …

Burp入门(7)-APP抓包

声明:学习视频来自b站up主 泷羽sec,如涉及侵权马上删除文章 感谢泷羽sec 团队的教学 视频地址:burpsuite(5)web网页端抓包与app渗透测试_哔哩哔哩_bilibili 本文详细介绍如何使用burp suite去抓取APP的数据包。 一、安装 Burp 的 CA 证书 1…

【AI+网络/仿真数据集】1分钟搭建云原生端到端5G网络

导语: 近期智慧网络开放创新平台上线了端到端网络仿真能力,区别于传统的网络仿真工具需要复杂的领域知识可界面操作,该平台的网络仿真能力主打一个小白友好和功能专业。 https://jiutian.10086.cn/open/​jiutian.10086.cn/open/ 端到端仿…

学习实验室—招投标实务

在如今业务为王的市场竞争中,招投标的成功率不仅仅取决于方案的质量,更多的是一些“隐形”的诀窍和经验。许多成功的背后,往往隐藏着那些别人不愿提及的细节与技巧。突破盲点,往往意味着“知道与不知道”的差距。 今天&#xff0…

ElasticSearch7.8学习笔记

1. ElasticSearch概述 1.1 ElasticSearch是什么 Elaticsearch,简称为 ES,ES 是一个开源的高扩展的分布式全文搜索引擎,是整个Elastic Stack 技术栈的核心。它可以近乎实时的存储、检索数据;本身扩展性很好,可以扩展到…

AI生成不了复杂前端页面?也许有解决方案了

在2024年,编程成为了人工智能领域最热门的赛道。AI编程技术正以惊人的速度进步,但在生成前端页面方面,AI的能力还是饱受质疑。自从ScriptEcho平台上线以来,我们收到了不少用户的反馈,他们表示:“生成的页面…

k8s部署odoo18(kubeshpere面板)

Postgresql部署 链接: kubesphere搭建 postgres15 因为我的是在另一台服务器使用kubesphere进行部署的,如果有和我一样情况的,可以参考上面的文档部署postgreasql。 注意事项: 因为odoo不允许使用postgresql的默认用户,也就是po…

友思特方案 | 精密制程的光影贴合:半导体制造中的高功率紫外光源

导读 为新能源锂电行业赋能第四站:半导体制造中的高功率紫外光源!稳定输出、灵活控制的曝光设备是新能源/半导体行业高端生产中减少误差、提高效率的核心技术,友思特 ALE 系列 UV LED 紫外光源集合6大优势,为精密制造的健康发展提…

数据结构 (36)各种排序方法的综合比较

一、常见排序方法分类 插入排序类 直接插入排序:通过构建有序序列,对于未排序数据,在已排序序列中从后向前扫描,找到相应位置并插入。希尔排序:是插入排序的一种改进版本,先将整个待排序的记录序列分割成为…

Datawhale AI冬令营 ——如何定制自己的专属大模型?

定制一个自己的专属大模型最方便的步骤 ≈ 指定数据集 开源大模型 微调平台(如讯飞星辰Maas) 内容很开门!very goo( ̄▽ ̄)d! 下面我将演示如何用讯飞星辰Maas平台甄嬛数据集构建Chat-嬛嬛。 …

【Pandas】pandas isna

Pandas2.2 General Top-level missing data 方法描述isna(obj)用于检测数据中的缺失值isnull(obj)用于检测数据中的缺失值notna(obj)用于检测数据中的非缺失值notnull(obj)用于检测数据中的非缺失值 pandas.isna() pandas.isna() 是 Pandas 库中的一个函数,用于…

STC单片机I2C驱动例程

STC单片机系列通常指的是由宏晶科技(Hangzhou Macro Crystal Technology Co., Ltd.)生产的8051内核的微控制器。这些单片机因其成本效益和易于使用而在嵌入式系统中广泛使用。对于I2C通信,STC单片机没有内置硬件I2C模块,因此需要通…

03_Webpack模块打包工具

03_Webpack模块打包工具 目录 知识点自测 以下哪个选项是 ECMAScript 默认导出和导入的语法? A:export 和 require B:module.exports {} 和 import 变量名 C:export default 和 import 变量名 D:export 和 import {…

使用WebStorm开发Vue3项目

记录一下使用WebStorm开发Vu3项目时的配置 现在WebStorm可以个人免费使用啦!?? 基本配置 打包工具:Vite 前端框架:ElementPlus 开发语言:Vue3、TypeScript、Sass 代码检查:ESLint、Prettier IDE:WebSt…

阿里云 云产品流转(实现设备与小程序交互)

一、准备工作 1、设备接入平台 创建两个设备接入到对应产品中,具体可以参考这里(点击跳转)。 二、云产品流转设置 在物联网平台下-->消息转发-->云产品流转->数据源 1、数据源 数据源-->创建数据源-->填写信息-->确定&…

如何使用 JavaScript 获取 URL 参数?

在 JavaScript 中,获取 URL 参数是非常常见的操作,尤其是在 Web 开发中,常常需要获取查询字符串(query string)中的参数值来控制页面展示或进行 API 请求等操作。 方法 1: 使用 URLSearchParams 对象 URLSearchParam…

SAFT(Synthetic Aperture Focusing Technique)基于合成孔径技术的图像重建方法

SAFT(Synthetic Aperture Focusing Technique)是一种基于合成孔径技术的图像重建方法,广泛应用于超声波成像、雷达成像等领域。它的核心思想是通过合成多个接收信号,模拟一个虚拟的更大孔径,从而提高成像系统的空间分辨率。与传统的成像方法相比,SAFT能够显著提高图像的质…

goLang之路(RSA加密算法)

RSA加密算法 RSA加密算法RSA之go与Java加解密算法对应关系签名算法对应关系密钥系列化与反序列化 生成密钥对密钥序列化为字符串(pkcs1标准不推荐再使用,而且Java标准库也不提供支持)密钥反序列化为密钥对象 留一个示例(Go与Java交…