go 日志框架

内置log
import ("log""os"
)func main() {// 设置loglog.SetFlags(log.Llongfile | log.Lmicroseconds | log.Ldate)// 自定义日志前缀log.SetPrefix("[pprof]")log.Println("main ..")// 如果用format就用PrintF,而不是Print打印,out: 2025/02/13 11:32:45 普通日志日志log.Printf("普通日志%s\n", "日志")/**2025/02/13 11:32:45 普通日志%s日志*/log.Print("普通日志%s\n", "日志")// 自定义logger := log.New(os.Stdout, "<New>", log.Lshortfile|log.Ldate|log.Ltime)logger.Println("这是自定义的logger记录的日志。")// 严重错误log.Fatalln("严重错误")// Panic系列函数会在写入日志信息后panic// 在 Go 语言中,panic 是一种用于处理程序异常情况的机制。//当程序遇到无法继续执行的严重错误时,可以通过 panic 触发一个运行时错误,//导致程序立即停止当前函数的执行,并开始执行延迟函数(defer),最后退出程序。log.Panic("使人惶恐的")
}
zap
github:https://github.com/uber-go/zap
import ("go.uber.org/zap"
)/*
*
{"level":"info","ts":1739418401.0806556,"caller":"src/test1.go:11","msg":"This i
s an info log","key":"value","count":1}
{"level":"warn","ts":1739418401.0812044,"caller":"src/test1.go:15","msg":"This i
s an info log","key":"value","count":1}
{"level":"error","ts":1739418401.0812044,"caller":"src/test1.go:19","msg":"This
is an info log","key":"value","count":1,"stacktrace":"main.main\n\t***src/test1.go:19\nruntime.main\n\tC:/Program Files/Go/src/runtime/proc.g
o:267"}
*/
func main() {logger, _ := zap.NewProduction()defer logger.Sync()logger.Info("This is an info log",zap.String("key", "value"),zap.Int("count", 1),)logger.Warn("This is an info log",zap.String("key", "value"),zap.Int("count", 1),)logger.Error("This is an info log",zap.String("key", "value"),zap.Int("count", 1),)
}
相关文章:
go 日志框架
内置log import ("log""os" )func main() {// 设置loglog.SetFlags(log.Llongfile | log.Lmicroseconds | log.Ldate)// 自定义日志前缀log.SetPrefix("[pprof]")log.Println("main ..")// 如果用format就用PrintF,而不是…...
如何在 PDF 文件中嵌入自定义数据
由于 PDF 文件格式功能强大且灵活,它经常被用于内部工作流程。有时候,将自定义数据嵌入 PDF 文件本身会非常有用。通常,这些信息会被大多数工具忽略,因此 PDF 仍然可以作为普通 PDF 文件正常使用。 以下是一些实现方法࿱…...
计算机毕业设计SpringBoot+Vue.js服装商城 服装购物系统(源码+LW文档+PPT+讲解+开题报告)
温馨提示:文末有 CSDN 平台官方提供的学长联系方式的名片! 温馨提示:文末有 CSDN 平台官方提供的学长联系方式的名片! 温馨提示:文末有 CSDN 平台官方提供的学长联系方式的名片! 作者简介:Java领…...
22.回溯算法4
递增子序列 这里不能排序,因为数组的顺序是对结果有影响的,所以只能通过used数组来去重 class Solution { public:vector<int> path;vector<vector<int>> res;void backtracking(vector<int>& nums,int start){if(path.si…...
linux -对文件描述符的操作dup、fcntl有五种
dup #include<unistd.h> int dup(int oldfd);作用:复制一个新的文件描述符fd 3, int fd1 dup(fd);f指向的是a.txt,fd1指向的也是a.txt从空闲的文件描述符表中找一个最小的作为新的拷贝的文件描述符返回:成功返回新的文件描述符,失败…...
技术解析 | 适用于TeamCity的Unreal Engine支持插件,提升游戏构建效率
龙智是JetBrains授权合作伙伴、Perforce授权合作伙伴,为您提供TeamCity、Perforce Helix Core等热门的游戏开发工具及一站式服务 TeamCity 是游戏开发的热门选择,大家选择它的原因包括支持 Perforce、可以进行本地安装,并提供了多种配置选项。…...
Ubuntu22.04 - brpc的安装和使用
目录 介绍安装使用 介绍 brpc 是用 c语言编写的工业级 RPC 框架,常用于搜索、存储、机器学习、广告、推荐等高性能系统 安装 先安装依赖 apt-get install -y git g make libssl-dev libprotobuf-dev libprotoc-dev protobuf-compiler libleveldb-dev libgflags-d…...
网络运维学习笔记 018 HCIA-Datacom综合实验02
文章目录 综合实验2sw3:sw4:gw:core1(sw1):core2(sw2):ISP 综合实验2 sw3: vlan 2 stp mode stp int e0/0/1 port link-type trunk port trunk allow-pass v…...
Vulhub靶机 Apache Druid(CVE-2021-25646)(渗透测试详解)
一、开启vulhub环境 docker-compose up -d 启动 docker ps 查看开放的端口 1、漏洞范围 在Druid0.20.0及更低版本中 二、访问靶机IP 8888端口 1、点击Load data进入新界面后,再点击local disk按钮。 2、进入新界面后,在标红框的Base directory栏写上…...
VSCode配置自动生成头文件
一、配置步骤: 1.打开命令面板(CtrlShiftp): 2.输入snippets 选择配置代码片段 3. 选择新建全局代码片段 输入文件名,比如header_cpp(随便定义),然后点击键盘回车按钮,得到下面这个文件。 增加配置文…...
Xcode如何高效的一键重命名某个关键字
1.选中某个需要修改的关键字; 2.右击,选择Refactor->Rename… 然后就会出现如下界面: 此时就可以一键重命名了。 还可以设置快捷键。 1.打开Settings 2.找到Key Bindings 3.搜索rename 4.出现三个,点击一个地方设置后其…...
React 高阶组件的优缺点
React 高阶组件的优缺点 优点 1. 代码复用性高 公共逻辑封装:当多个组件需要实现相同的功能或逻辑时,高阶组件可以将这些逻辑封装起来,避免代码重复。例如,多个组件都需要在挂载时进行数据获取操作,就可以创建一个数…...
(五)趣学设计模式 之 建造者模式!
目录 一、 啥是建造者模式?二、 为什么要用建造者模式?三、 建造者模式怎么实现?四、 建造者模式的应用场景五、 建造者模式的优点和缺点六、 总结 🌟我的其他文章也讲解的比较有趣😁,如果喜欢博主的讲解方…...
香橙派/树莓派 利用Wiring库 使用GPIO模拟PWM
香橙派或者树莓派 等开发板,本身带有硬件PWM,比如香橙派3 lts版,但是这个引脚不符合我的项目需求,我需要外接一个电机,在检测到人脸的时候 转动,但是这个硬件引脚,只要上电就开始输出pwm 信号,导…...
全面收集中间件Exporter适配:从Redis到ActiveMQ,掌握监控数据采集的最佳实践
#作者:任少近 文章目录 说明:一 Redis的适配exporter版1.1 Redis的exporter源码版本1.2 Redis的exporter的releases版1.3 Redis_exporter版本选择理由1.4 Redis_exporter docer镜像 二 Zookeeper的适配exporter版2.1 Zookeeper的exporter源码版本2.2 Zo…...
机器学习数学通关指南——链式法则
前言 本文隶属于专栏《机器学习数学通关指南》,该专栏为笔者原创,引用请注明来源,不足和错误之处请在评论区帮忙指出,谢谢! 本专栏目录结构和参考文献请见《机器学习数学通关指南》 正文 一、定义与公式 链式法则&a…...
JavaScript函数-arguments的使用
在JavaScript编程语言中,函数是构建复杂逻辑和实现代码复用的关键组件。虽然现代JavaScript(尤其是ES6及之后版本)提供了更多灵活的方式来处理函数参数(如剩余参数、默认参数等),但arguments对象仍然是一个…...
千峰React:函数组件使用(2)
前面写了三千字没保存,恨! 批量渲染 function App() {const list [{id:0,text:aaaa},{id:1,text:bbbb},{id:2,text:cccc}]// for (let i 0; i < list.length; i) {// list[i] <li>{list[i]}</li>// }return (<div><…...
DPVS-3: 双臂负载均衡测试
测试拓扑 双臂模式, 使用两个网卡,一个对外,一个对内。 Client host是物理机, RS host都是虚拟机。 LB host是物理机,两个CX5网卡分别在两个子网。 配置文件 用dpvs.conf.sample作为双臂配置文件,其中…...
2016年下半年试题二:论软件设计模式及其应用
论文库链接:系统架构设计师论文 论文题目 软件设计模式(Software DesignPatter)是一套被反复使用的、多数人知晓的、经过分类编目的代码设计经验的总结。使用设计模式是为了重用代码以提高编码效率增加代码的可理解性、保证代码的可靠性。软件设计模式是软件开发中的…...
zmq源码分析之管道创建pipepair
文章目录 一、函数签名与参数 参数详解: 二、函数实现逐行解析 **第 1 步:定义底层队列类型** **第 2 步:创建第一个方向的队列** **第 3 步:创建第二个方向的队列** **第 4 步:创建两个管道对象(关键!)** **第 5 步:设置互为对等体** 三、pipe_t 构造函数详解 四、实…...
Asian Beauty Z-Image Turbo 技术解析:透过LSTM理解序列生成在扩散模型中的角色
Asian Beauty Z-Image Turbo 技术解析:透过LSTM理解序列生成在扩散模型中的角色 最近在图像生成圈子里,Asian Beauty Z-Image Turbo这个名字挺火的。很多人被它出图的速度和效果惊艳到,但一聊到背后的技术,尤其是那个“时间步”的…...
**标题:MLOps实战进阶:用Python + Docker + Airflow打造自动化机器学习
标题:MLOps实战进阶:用Python Docker Airflow打造自动化机器学习流水线 在现代AI项目中,模型开发不再是“一次性任务”,而是持续迭代、版本控制、部署监控的完整生命周期管理过程。这正是 MLOps(Machine Learning Op…...
规划失败怎么办:回退、改写与再规划策略
规划失败怎么办:回退、改写与再规划全链路策略 副标题:从软件工程、AI Agent到企业战略的通用可落地框架,附代码实现与实战案例 第一部分:引言与基础 1.1 摘要/引言 你有没有遇到过这些崩溃时刻: 花了3个月做的技术规划,上线第一天就出现核心链路故障,半年的投入几乎…...
Brigadier:企业级Mac驱动自动化部署的智能化解决方案
Brigadier:企业级Mac驱动自动化部署的智能化解决方案 【免费下载链接】brigadier Fetch and install Boot Camp ESDs with ease. 项目地址: https://gitcode.com/gh_mirrors/bri/brigadier 在混合计算环境中,Mac设备的Boot Camp驱动部署一直是IT管…...
两道必掌握的动态规划面试题:最长回文子串 最长公共子序列
目录 一、最长回文子串(Longest Palindromic Substring) 题目描述 1. 暴力解法(时间复杂度 O (n)) 2. 中心扩展法(时间复杂度 O (n),空间 O (1)) 核心思路 Java 代码实现 3. 动态规划解法…...
从‘换脸’到‘换物’:手把手用Attention-GAN实现图片局部精准转换(避坑指南)
从‘换脸’到‘换物’:手把手用Attention-GAN实现图片局部精准转换(避坑指南) 在数字图像处理领域,生成对抗网络(GAN)技术已经从早期的整体风格迁移发展到如今的局部精准编辑。想象这样一个场景:…...
保姆级教程:在Ubuntu 22.04上为全志D1s/F133 MangoPi-MQ编译Tina Linux(含SDK结构解析)
全志D1s/F133开发板Tina Linux编译实战指南:从环境搭建到固件烧录 第一次拿到MangoPi-MQ这块小巧的开发板时,我对着全志Tina Linux的SDK文档发了半小时呆——lichee目录是干什么的?device和package又有什么区别?为什么官方教程里的…...
HTML怎么实现记住我功能_HTML checkbox保存登录状态【方法】
HTML checkbox 本身不能“记住我”,需用 JavaScript 结合 localStorage 持久化勾选状态,并将 remember 信号传给后端以发放长期 HttpOnly cookie,前端不可存密码,且须兼容 Safari 隐私模式与 WebView 限制。HTML checkbox 本身不能…...
OFA图像语义蕴含模型保姆级部署指南:从零到一搭建Web应用
OFA图像语义蕴含模型保姆级部署指南:从零到一搭建Web应用 1. 项目概述与技术背景 1.1 什么是图像语义蕴含 图像语义蕴含(Visual Entailment)是多模态AI领域的一项重要任务,它需要系统判断给定的文本描述是否能够从图像内容中逻…...
