Panic 处理

本文介绍 Kitex 对 panic 的处理说明。

使用说明

  • 业务代码使用 go 关键字创建的 goroutine 里发生的 panic,需要业务自行 recover;受限于语言提供的能力, 无法由框架 Recover;
  • 为了保证服务的稳定,Kitex 框架会自动 recover 其他所有 panic。

FAQ

Q: 如何在 Server 中间件中 recover panic?

结论:不能;但框架提供获取该 panic 详情的方式。

Kitex 框架会自行 recover 业务 handler 里发生的 panic,并且(暂)不提供任何在此前插入 recover 逻辑或者中间件的手段。

Q: 获取被 recover 的 panic 详情

你可以在自己的中间件里检查是否发生过 panic,方式如下:

// 在中间件里调用 next(...) 之后:
ri := rpcinfo.GetRPCInfo(ctx)
if stats := ri.Stats(); stats != nil {
    if panicked, err := stats.Panicked(); panicked {
        // `err` 就是框架调用 recover() 收到的对象
    }
}

最后修改 January 9, 2024 : docs: update access log option (#920) (e701a6d)