异常之道:探索Java异常处理与日志的黄金准则

本文涉及的产品
.cn 域名,1个 12个月
日志服务 SLS,月写入数据量 50GB 1个月
简介: 异常之道:探索Java异常处理与日志的黄金准则

异常处理与日志规范

  1. 底层原始异常不要捕获直接向外抛出,一直往外抛出,直到 Service 或者 Controller;
  2. 自定义的 BusinessException 异常统一在 Controller 层进行汇总处理;
  3. 其他异常需要首先在 Service 层进行 error 级别日志记录,之后向外层抛出 BusinessException 并调用 setCause 设置造成原因(注意 Service 只能向外抛出 BusinessException,其他异常需要进行异常转换);
  4. Controller 层不要再向外抛出异常,需要在 Controller 层进行捕获操作
  • 如果返回的是 RespResult,在 catch 中返回 RespResult.fail
  • 如果返回的是页面,在 catch 中返回 "redirect:/500"
  • Controller 层捕获异常的时候不需要打印错误日志
  1. 系统只处理受检异常,运行时异常不要捕获也不要抛出,属于Bug,应当解决;
  2. 进行异常转换时都要进行 error 级别日志记录,并且调用 initCause 方法设置错误原因;
  3. Service 层向外抛出自定义的 BusinessException 异常,由调用此 Service 的 Controller 或者定时任务捕获处理;
  4. 抛出定义的 CdnHuaweiException 或 BusinessException 是可以使用链式调用的方式快捷打印日志,示例如下:
  • throw new CdnHuaweiException("XXXX发生错误!错误原因:{}", e.getMessage()).setCause(e).log();
  1. 其他特殊类(Bean、Component、Interceptor…)的异常处理和日志打印规则可自行处理;

程序示例

DomainConfigureApi.java

public static JSONObject getDomainConfigs(String domainName) throws CdnHuaweiException {
    try {
        Request request = HuaweiRequest.getRequest(CdnConst.GET_DOMAIN_CONFIGS.replace("{domain_name}", domainName), "GET");
        Response response = HuaweiRequest.doRequest(request);
        return HuaweiRequest.dealResponse(response);
    } catch (Exception e) {
        log.error("查询域名配置接口失败!错误原因:{}", e.getMessage());
        throw new CdnHuaweiException("查询域名配置接口失败!错误原因:{}", e.getMessage()).setCause(e);
        // 如果打印的日志和报错的信息一样,那么上面两行代码也可以使用下面代替
        // throw new CdnHuaweiException("查询域名配置接口失败!错误原因:{}", e.getMessage()).setCause(e).log();
    }
}

CdnDomainService.java

public JSONObject getDomainConfig(String domainName) throws BusinessException {
    JSONObject jsonObject = null;
    try {
        jsonObject = DomainConfigureApi.getDomainConfigs(domainName);
    } catch (CdnHuaweiException e) {
        log.error("获取域名的详细配置失败,域名:{}", domainName);
        throw new CdnHuaweiException("获取域名的详细配置失败!错误原因:{}", e.getMessage()).setCause(e);
    }
    JSONObject configs = jsonObject.getJSONObject("configs");
    // 解析主源站
    JSONArray sourcesArray = configs.getJSONArray("sources");
    for (int i = 0; i < sourcesArray.size(); i++) {
        JSONObject source = sourcesArray.getJSONObject(i);
        if (source.getInteger("priority") == SourcePriority.MAIN) {
            configs.put("main_source", source);
        }
        if (source.getInteger("priority") == SourcePriority.BACK) {
            configs.put("back_source", source);
        }
    }
    return configs;
}

DomainSettingsPageController.java

@GetMapping("/domain-setting-basic")
public String domainBasicSettings(Long id, Map<String, Object> map) {
    if (Assert.isEmpty(id)) {
        return "redirect:/400";
    }
    CdnDomainVo cdnDomainVo = cdnDomainService.getCdnDomainVoById(id);
    if (Assert.isEmpty(cdnDomainVo)) {
        return "redirect:/404";
    }
    // 获取域名的详细配置
    try {
        JSONObject domainConfig = cdnDomainService.getDomainConfig(cdnDomainVo.getDomainName());
        map.put("domainConfig", domainConfig);
    } catch (BusinessException e) {
        return "redirect:/500";
    }
    // 查询所有的业务类型
    List<CdnBusinessType> businessTypes = cdnBusinessTypeService.queryAll();
    // 查询所有的业务范围
    List<CdnServiceArea> serviceAreas = cdnServiceAreaService.queryAll();
    // 查询所有源站类型
    List<CdnOriginType> originTypes = cdnOriginTypeService.queryAll();
    map.put("businessTypes", businessTypes);
    map.put("serviceAreas", serviceAreas);
    map.put("originTypes", originTypes);
    map.put("domain", cdnDomainVo);
    return "admin/domain/domain-setting-basic";
}


相关实践学习
日志服务之使用Nginx模式采集日志
本文介绍如何通过日志服务控制台创建Nginx模式的Logtail配置快速采集Nginx日志并进行多维度分析。
相关文章
|
1天前
|
Java 程序员
Java中的异常处理:从基础到高级
【8月更文挑战第30天】在Java编程的世界中,异常处理是一块重要的拼图。它不仅确保了程序的健壮性,还提高了代码的可读性和可维护性。本文将带你深入理解Java的异常处理机制,从基本的try-catch块到高级的自定义异常和最佳实践,我们将一起探索如何优雅地处理那些不请自来的错误信息。
25 17
|
1天前
|
Java 数据库连接 UED
Java中的异常处理:从基础到高级
【8月更文挑战第30天】在Java的世界里,异常是程序运行中不可避免的挑战。本文将引导你理解Java的异常处理机制,从基本的try-catch语句到高级的自定义异常和最佳实践。我们将一起探索如何优雅地处理错误,确保程序的健壮性和可靠性。
19 13
|
2天前
|
存储 搜索推荐 Java
探索安卓开发中的自定义视图:打造个性化UI组件Java中的异常处理:从基础到高级
【8月更文挑战第29天】在安卓应用的海洋中,一个独特的用户界面(UI)能让应用脱颖而出。自定义视图是实现这一目标的强大工具。本文将通过一个简单的自定义计数器视图示例,展示如何从零开始创建一个具有独特风格和功能的安卓UI组件,并讨论在此过程中涉及的设计原则、性能优化和兼容性问题。准备好让你的应用与众不同了吗?让我们开始吧!
|
1天前
|
消息中间件 算法 Java
深入浅出操作系统:进程管理的艺术掌握Java中的异常处理机制
【8月更文挑战第30天】在数字世界的舞台上,操作系统扮演着导演的角色,精心安排着每一个进程的表演。本文将揭开进程管理的神秘面纱,从进程的诞生到终结,探究它们如何在操作系统的指挥下和谐共舞。通过生动的比喻和直观的代码示例,我们将一同走进操作系统的核心,理解进程调度、同步与通信的内在机制,以及它们对计算生态的重要性。让我们跟随代码的节奏,一起感受操作系统的魅力吧!
|
2天前
|
Java 开发者
Java中的异常处理:从基础到高级
【8月更文挑战第30天】在Java的世界中,异常处理是每个开发者必须面对的挑战。本文不仅教你如何在代码中优雅地处理异常,还将深入探讨如何设计异常类和自定义异常,让你的Java程序更加健壮和易于维护。让我们一起探索Java异常处理的秘密,从新手到高手,只需一篇文章的距离!
|
2天前
|
Java 编译器 开发者
Java中的异常处理机制
【8月更文挑战第30天】在Java编程中,异常处理是不可或缺的一部分。本文将探讨Java的异常处理机制,包括异常的概念、分类以及如何处理异常。我们将通过实际代码示例来展示如何在Java程序中捕获和处理异常,确保程序的稳定性和可靠性。无论你是初学者还是有经验的开发者,这篇文章都将帮助你更好地理解和应用Java的异常处理机制。
5 1
|
2天前
|
Java UED
深入浅出Java异常处理
【8月更文挑战第29天】在Java的世界里,异常是程序运行中不可忽视的“小石头”。它们可能让代码执行路径发生偏移,甚至导致程序崩溃。掌握好Java异常处理的技巧,就像学会在崎岖的道路上稳稳行走。本文将带你了解如何优雅地处理这些“小石头”,确保你的程序能够稳健前行。
|
1天前
|
安全 Java
深入浅出Java异常处理机制
【8月更文挑战第30天】在Java编程世界中,异常处理是维护程序健壮性的重要手段。本文将带你一探Java异常处理的奥秘,从基本的异常类型到高级的处理策略,我们用简单的语言和生动的比喻,让你像拼图一样轻松掌握每个部分。准备好,让我们一起揭开异常处理的面纱,学会如何优雅地应对程序中的“意外惊喜”。
|
1天前
|
IDE Java Linux
探索安卓开发:从基础到进阶的旅程Java中的异常处理:从基础到高级
【8月更文挑战第30天】在这个数字时代,移动应用已经成为我们日常生活中不可或缺的一部分。安卓系统由于其开放性和灵活性,成为了开发者的首选平台之一。本文将带领读者踏上一段从零开始的安卓开发之旅,通过深入浅出的方式介绍安卓开发的基础知识、核心概念以及进阶技巧。我们将一起构建一个简单的安卓应用,并探讨如何优化代码以提高性能和应用的用户体验。无论你是初学者还是有一定经验的开发者,这篇文章都将为你提供宝贵的知识和启发。
|
2天前
|
存储 消息中间件 监控
Java日志详解:日志级别,优先级、配置文件、常见日志管理系统ELK、日志收集分析
Java日志详解:日志级别,优先级、配置文件、常见日志管理系统、日志收集分析。日志级别从小到大的关系(优先级从低到高): ALL < TRACE < DEBUG < INFO < WARN < ERROR < FATAL < OFF 低级别的会输出高级别的信息,高级别的不会输出低级别的信息
下一篇
云函数