Golang stackError 补充go错误定位能力力
用过go的都知道,go的error实现很简单,errors.New实现的error类并不存储堆栈数据,这导致一个问题,就是多次error return后,或panic后recover了,找不到触发异常的位置,这导致问题排查进一步很难定位。stackError实现类似于 java中的exception类,里面可以存储堆栈数据,并且通过单向链表记录error的触发嵌套关系,使日志追踪变的更加容易!
后来得天一个github.com/pkg/errors 很好实现堆栈追踪。
另外配合http://github.com/lingdor/midlog 可以实现很好的日志记录功能
1、stackError的引用
go get 获取
go get github.com/lingdor/stackerror
go.mod
require github.com/lingdor/stackerror 0.1.6
go mod download
2、堆栈定位
func act1()error { return stackerror.New("here Error") } func main(){ err:=act1() fmt.println(err.Error()) }
输出:
*stackError.stackError : here Error
at main.act1( /Users/user/go/testMain/src/main/main.go:17 )
at main.main( /Users/user/go/testMain/src/main/main.go:22 )
at runtime.main( /usr/local/Cellar/go/1.13.4/libexec/src/runtime/proc.go:203 )
3、使用派生error
func act1() error { return stackerror.New("here Error") } func main() { er := act1() ParentErr := stackerror.NewParent("act1 error", er) fmt.Println(ParentErr.Error()) }
输出:
*stackError.stackError : act1 error
at main.main( /Users/user/go/testMain/main.go:22 )
at runtime.main( /usr/local/Cellar/go/1.13.4/libexec/src/runtime/proc.go:203 )
*stackError.stackError : here Error
at main.act1( /Users/user/go/testMain/main.go:16 )
at main.main( /Users/user/go/testMain/main.go:21 )
at runtime.main( /usr/local/Cellar/go/1.13.4/libexec/src/runtime/proc.go:203 )
4、优雅处理error
//不用写哪么多if判断 func main() { err := act1() stackerror.CheckPanic(err) }
//可以日志清晰定位panic的位置 func main() { defer func(){ if err := recover();err!=nil { fmt.Println(err) } }() stackerror.Panic("here") }
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 地球OL攻略 —— 某应届生求职总结
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 提示词工程——AI应用必不可少的技术
· .NET周刊【3月第1期 2025-03-02】