• 异常处理


    对于大型IT系统,最怕的事情第一是系统出现了异常我不知道,等问题闹大了用户投诉了才知道出问题了。第二就是出了问题之后无法找到出错原因。针对这2个问题,说说我们项目组是怎么样规定异常处理的。

    系统出异常了我不知道,等问题闹大了用户投诉了才知道。这个问题出现非常多,而且非常严重。我不知道其他公司有没有这种场景,对我们公司而言,经常会出现用户反馈、投诉过来说某个功能不可用,开发人员定位分析之后,才发现之前的某一步出错了。公司业务流程非常复杂,和周边系统一堆集成,一堆的后台队列任务,任何一部都可能出问题。

    举几个今年真实的案例:

    1 某系统销户无法成功,最后定位发现前段时间ldap密码修改没有更新

    2 某个流程失败,最后发现集成的系统新增加了NAS盘,防火墙不通无法访问导致报错。

    3 某个功能无法使用,查看日志发现后台定时任务已经停了好几天。

    针对这些功能,在流程上当然可以采取相对的策略来保证,但从开发的角度来说,任何规定都无法保证一定不会发生错误,老虎也有打盹的时候,我只相信代码。

    我对开发人员的要求就是,绝大部分场景,不允许捕获异常,不要乱加空判断。只有明显不需要关心的异常,如关闭资源的时候的io异常,可以捕获然后什么都不干,其他时候,不允许捕获异常,都抛出去,到controller处理。空判断大部分时候不需要,你如果写了空判断,你就必须测试为空和不为空二种场景,要么就不要写空判断。

    强调,有些空判断是要的,如:参数是用户输入的情况下。但是,大部分场景是不需要的(我们的IT系统里面,一半以上不需要),如参数是其它系统传过来,或者其他地方获取的传过来的,99.99%都不会为空,你判断来干嘛?就抛一个空指针到前台怎么啦?何况基本上不会出现。

    新手最容易犯的错误,到处捕获异常,到处加空判断,自以为写出了“健壮”的代码,实际上完全相反。导致的问题,第一代码可读性很差,你如果工作了看到一半代码是try-catch和空判断你会同意我的观点的,第二更加重要的掩盖了很多错误,如上面图片的例子!日志是不会有人看的,我们的目的是尽早让错误抛出来,还有,你加了空判断,那你测试过为空的场景吗?

    web请求上的异常,不允许开发人员捕获,直接抛到前台,会有controller处理!

    另外一种后台定时任务队列的异常,其实思路是一样的,有个统一的地方处理异常,里面的代码同样不准捕获异常!然后异常的时候邮件通知到我和开发人员,开发组长必须知道后台的任何异常,不要等用户投诉了才知道系统出问题了。

    另外,开发组长需要自己定义好系统里面的异常,其实能定义的没有几种,太细了很难落地,来,异常不要继承Exception,而是继承RuntimeException,否则到时候从头改到尾就为了加个异常声明你就觉得很无聊

    public class CheckException extends RuntimeException{
    
        public CheckException(){
    
        }
    
        public CheckException(String message){
            super(message);
        }
    
        public CheckException(Throwable cause){
            super(cause);
        }
    
        public CheckException(String message,Throwable cause){
            super(message,cause);
        }
    
        public CheckException(String message, Throwable cause,
                              boolean enableSuppression,
                              boolean writableStackTrace){
            super(message,cause,enableSuppression,writableStackTrace);
        }
    }

    总结:

    1. 开发组长定义好异常,异常继承RuntimeException。
    2. 不允许开发人员捕获异常。(异常上对开发人员就这点要求!异常都抛出到controller上用AOP处理)
    3. 后台(如队列等)异常一定要有通知机制,要第一时间知道异常。
    4. 少加空判断,加了空判断就要测试为空的场景!

    原文链接:https://zhuanlan.zhihu.com/p/29005176?group_id=888502345451839489

  • 相关阅读:
    Vim step by step
    Ubuntu解压命令全览
    这样才能使本地Mysql服务允许被外部主机连接(两步)
    [Python] logging.logger
    Python Selenium
    MySQL中char、varchar和text的区别
    Way to MongoDB
    Python误区之strip,lstrip,rstrip
    Android Studio Tips
    Way to tmux
  • 原文地址:https://www.cnblogs.com/shareTechnologyl/p/11713840.html
Copyright © 2020-2023  润新知