前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >异常处理规范

异常处理规范

作者头像
只喝牛奶的杀手
发布2023-11-27 18:34:33
1670
发布2023-11-27 18:34:33
举报

就在本周排查一个生产环境请求丢失问题的,我私下感觉纯粹就在浪费时间,也只能是私下。问题描述:调用方通过开放平台的接口报了一个null。而且调用方自己打印的有日志,云网关那边也有日志,开放平台也有日志,上游也有日志。开放平台提供的SDK的错误日志用的e.printStackTrace()。

几个人靠对日志去看,同一秒多次请求很正常,而且每个服务器的时间有可能不一样。也没有requestId之类的东西,让你确定是同一个请求。请求到底真正发出去没有,也是个问题。这个时候显得日志很重要,打印好日志很重要,尤其是跨系统排查问题显的更加重要。

解决问题不能靠猜,需要有上下文,别人说的上下文就一定是上下文吗?你确定这个请求就是报错的请求吗?如果不能确定,就先不要猜,也不要出那些所谓的解决方案。

这里再整理系统异常处理的原则和处理规范,应该注意的事项:

  • 不要吞掉Exception,不要在业务代码中进行捕获异常, 即 Dao, Manage、Service, Controller 层的所有异常都全部抛出到上层. 这样不会导致业务代码中的一堆 try-catch 导致业务代码混乱。
  • 哪一层都不捕获。自个处理完,抛到最外层, 最外层统一捕捉。
  • 处理好每一层的异常,返回统一的结果集 ( 错误码 + 错误描述 )。
  • 统一框架层处理。
  • 需要封装成自己的业务Exception定义为Runtime类型。
  • 任何的报错需要在在返回的header上面标注一个错误代码,方便调用方处理合适的异常,包括抛出合理的业务错误代码。以及记录请求的各种参数。
  • 中间件的一些异常,需要带上自己的错误处理, 如果不能完全捕捉。异常处理尽量不要太宽泛。
  • 鉴权的异常单独处理。

一个错误描述的基本信息应该包含:

  • 编码
  • 描述
  • 状态
  • 来自于那个系统及 系统的那一层,表单验证层or业务逻辑层or数据库层。那个系统可以给每个系统的统一AppKey。
  • requestId,尤其是夸系统调用,夸微服务调用的时候显的很重要
  • 严重程度:R1、R2、R3等

没有具体的根据去分析问题,找出问题算侥幸。大家都知道记叙文三要素是时间、地点、人物。以及六要素包括时间、地点、人物、(事件的)起因、经过和结果。当出现问题的时候,通过异常处理,把我们需要的关键信息描述清楚这样的异常处理才有价值。好像看似有些系统有异常处理,好像跟没有差别不大。减少技术支持时间,减少排查问题的时间才是好的异常处理。

精进自省:我生来就是高山而非溪流 ,我欲于群峰之巅俯视平庸的沟壑。我生来就是人杰而非草芥,我站在伟人之肩藐视卑微的懦夫。

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2023-11-25,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 只喝牛奶的杀手 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 就在本周排查一个生产环境请求丢失问题的,我私下感觉纯粹就在浪费时间,也只能是私下。问题描述:调用方通过开放平台的接口报了一个null。而且调用方自己打印的有日志,云网关那边也有日志,开放平台也有日志,上游也有日志。开放平台提供的SDK的错误日志用的e.printStackTrace()。
相关产品与服务
消息队列 TDMQ
消息队列 TDMQ (Tencent Distributed Message Queue)是腾讯基于 Apache Pulsar 自研的一个云原生消息中间件系列,其中包含兼容Pulsar、RabbitMQ、RocketMQ 等协议的消息队列子产品,得益于其底层计算与存储分离的架构,TDMQ 具备良好的弹性伸缩以及故障恢复能力。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档