golang 打印error的堆栈信息操作
众所周知,目前的golang error只关注Error()信息,而不关注它的堆栈路径,对错误的定位大多数通过
log.SetFlags(log.Llongfile| log.LstdFlags) log.Println(e)
一旦代码分层,为了定位错误,可能出现每一个层次的同一个error,都得log好几次,比如:
func DB()error{ return errors.New("time out") } func Dao()error{ if er:= DB();er!=nil{ log.Println(er) return error } return nil } func Service()error{ if er:= Dao();er!=nil{ log.Println(er) return error } return nil } func Control()error{ if er:= Service();er!=nil{ log.Println(er) return error } return nil }
如何一次性抛出错误,把该错误的堆栈全部都拿住呢
以模拟一次请求-分发-服务-数据库操作为例:
package main import ( "errors" "fmt" "github.com/fwhezfwhez/errorx" ) func main() { if e := Control(); e != nil { e.(errorx.Error).PrintStackTrace() // log.Println(e.(errorx.Error).StackTrace()) } else { Reply() } } // assume an engine to connect mysql func DB() error { return errors.New("connect to mysql time out") } // handle database operation func Dao() error { if er := DB(); er != nil { return errorx.New(er) } return nil } // handle logic service func Service() error { if er := Dao(); er != nil { return errorx.Wrap(er) } return nil } // handle request distribute from main func Control() error { if er := Service(); er != nil { return errorx.ReGen(er, errors.New("inner service error,please call admin for help")) } return nil } // reply a the request func Reply(){ fmt.Println("handle success") }
执行结果:
StackTrace | CausedBy
G:/go_workspace/GOPATH/src/errorX/example/main.go: 26 | connect to mysql time out
G:/go_workspace/GOPATH/src/errorX/example/main.go: 34 | connect to mysql time out
G:/go_workspace/GOPATH/src/errorX/example/main.go: 42 | inner service error,please call admin for help
补充:golang 异常退出堆栈捕获
利用golang自带包 runtime/debug 异常时打印
DebugInfo.go
package main import ( "fmt" "os" "runtime/debug" "time" ) func TryE() { errs := recover() if errs == nil { return } exeName := os.Args[0] //获取程序名称 now := time.Now() //获取当前时间 pid := os.Getpid() //获取进程ID time_str := now.Format("20060102150405") //设定时间格式 fname := fmt.Sprintf("%s-%d-%s-dump.log", exeName, pid, time_str) //保存错误信息文件名:程序名-进程ID-当前时间(年月日时分秒) fmt.Println("dump to file ", fname) f, err := os.Create(fname) if err != nil { return } defer f.Close() f.WriteString(fmt.Sprintf("%v\r\n", errs)) //输出panic信息 f.WriteString("========\r\n") f.WriteString(string(debug.Stack())) //输出堆栈信息 }
测试异常捕获 main.go
package main import ( "fmt" "time" ) func main() { defer TryE() fmt.Println(time.Now()) panic(-2) fmt.Println("panic restore now, continue.") }
查看堆栈可以定位main 里第11行抛出异常-2.
以上为个人经验,希望能给大家一个参考,也希望大家多多支持猪先飞。如有错误或未考虑完全的地方,望不吝赐教。
相关文章
- 在程序员中,尤其是go新手,经常听到的一个讨论话题是:如何处理错误,这篇文章主要给大家介绍了关于Go应用中优雅处理Error的一些相关技巧,需要的朋友可以参考下...2021-09-08
- 这篇文章主要介绍了js如何实现浏览器打印功能,文中示例代码非常详细,帮助大家更好的理解和学习,感兴趣的朋友可以了解下...2020-07-15
- 这篇文章主要介绍了golang 调用 php7详解及实例的相关资料,需要的朋友可以参考下...2017-01-15
解决Docker中的error during connect异常情况
这篇文章主要介绍了解决Docker中的error during connect异常情况,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...2020-11-22- 这篇文章主要介绍了c#如何获取已安装的打印机并调用打印文件,帮助大家更好的理解和使用c#,感兴趣的朋友可以了解下...2020-12-08
- 这篇文章主要为大家详细介绍了vue实现页面打印自动分页的两种方法,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...2021-09-29
- 这篇文章主要介绍了用golang实现替换某个文件中的字符串操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...2021-04-25
Springboot+MDC+traceId日志中打印唯一traceId
本文主要介绍了Springboot+MDC+traceId日志中打印唯一traceId,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...2021-10-17error LNK2019: 无法解析的外部符号 问题的解决办法
error LNK2019: 无法解析的外部符号 问题的解决办法,需要的朋友可以参考一下...2020-04-25- 这篇文章主要介绍了golang在GRPC中设置client的超时时间,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...2021-04-27
关于MySQL绕过授予information_schema中对象时报ERROR 1044(4200)错误
这篇文章主要介绍了关于MySQL绕过授予information_schema中对象时报ERROR 1044(4200)错误,本文给大家分享解决方法,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下...2020-10-17- 这篇文章主要介绍了解决Golang json序列化字符串时多了\的情况,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...2020-12-24
Golang中的自定义类型之间的转换的实现(type conversion)
这篇文章主要介绍了Golang中的自定义类型之间的转换的实现(type conversion),文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧...2021-02-21- 这篇文章主要介绍了golang与php实现计算两个经纬度之间距离的方法,结合实例形式对比分析了Go语言与php进行经纬度计算的相关数学运算技巧,需要的朋友可以参考下...2016-07-29
- 这篇文章主要介绍了C#操作excel打印的示例,帮助大家利用c#打印表格,提高办公效率,感兴趣的朋友可以了解下...2020-12-08
解决golang处理http response碰到的问题和需要注意的点
这篇文章主要介绍了解决golang处理http response碰到的问题和需要注意的点,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...2020-12-16- 这篇文章主要介绍了C#基本打印事件用法,实例分析了C#中print打印及DrawString文本字符串绘制等相关技巧,需要的朋友可以参考下...2020-06-25
- 这篇文章主要介绍了golang http使用踩过的坑与填坑指南,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...2021-04-27
- 这篇文章主要介绍了golang文件读取-按指定BUFF大小读取方式,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...2020-12-22
- Go(又称Golang)是Google开发的一种静态强类型、编译型、并发型,并具有垃圾回收功能的编程语言。这篇文章给大家介绍golang 正则表达式的相关知识,感兴趣的朋友跟随小编一起看看吧...2021-05-07