求教: golang error 和 log 的最佳实践思路
31 December 2024 at 13:40
Ayanokouji: 用 go 写业务时,遇到 error 时,大多数情况只能一路向上 return err ,我们基于这个场景讨论。
这个场景,和 java 写业务遇到的 checked exception 很类似,写代码时,只能一路向上 throw (或者 catch 住 throw new unchecked exception ),最终由框架统一处理。
如果遇到 go 遇到经验不足的开发者(比如以前的我),就会看到这样的错误日志:
Error: unexpected '>' at the beginning of value
Error: EOF
Error: wrong argument value
嗯。。。这 tm 是啥啊,到底是哪一行代码出错啊。
调用链越长,问题越难排查。
比较通用的 web 业务调用链,一般是 handler -> service -> 中间件(数据库/redis/第三方 api 等)
随着坑踩的多了,现在遇到 err, 一般是 return fmt.Errorf("xxx:%w", err)
日志一般在 handler 层 slog.log("xxx", slog.Any("request", req), slog.Any("err", err))
但是缺少了调用栈,总觉得少了点什么。
请教下各位,如何平衡 error 和 log ,主要是服务于问题排查。
看过 echo 和 huma 的框架 error 处理,都是自定义 err ,框架统一处理
------
ps:那些上来只踩一脚 java 的,还是去多写写代码吧,这种 err ( unexpected '>' at the beginning of value ) 真的比 excetiop (含调用栈) 强吗。
这个场景,和 java 写业务遇到的 checked exception 很类似,写代码时,只能一路向上 throw (或者 catch 住 throw new unchecked exception ),最终由框架统一处理。
如果遇到 go 遇到经验不足的开发者(比如以前的我),就会看到这样的错误日志:
Error: unexpected '>' at the beginning of value
Error: EOF
Error: wrong argument value
嗯。。。这 tm 是啥啊,到底是哪一行代码出错啊。
调用链越长,问题越难排查。
比较通用的 web 业务调用链,一般是 handler -> service -> 中间件(数据库/redis/第三方 api 等)
随着坑踩的多了,现在遇到 err, 一般是 return fmt.Errorf("xxx:%w", err)
日志一般在 handler 层 slog.log("xxx", slog.Any("request", req), slog.Any("err", err))
但是缺少了调用栈,总觉得少了点什么。
请教下各位,如何平衡 error 和 log ,主要是服务于问题排查。
看过 echo 和 huma 的框架 error 处理,都是自定义 err ,框架统一处理
------
ps:那些上来只踩一脚 java 的,还是去多写写代码吧,这种 err ( unexpected '>' at the beginning of value ) 真的比 excetiop (含调用栈) 强吗。