异常之道:探索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日志并进行多维度分析。
相关文章
|
21天前
|
Java 开发者
Java中的异常处理:从基础到高级
在Java编程的世界里,异常处理是一块基石,它确保了程序的健壮性和稳定性。本文将带你从异常的基础概念出发,逐步深入到高级处理技巧,通过实例展示如何在Java中有效管理和处理异常。无论你是初学者还是有经验的开发者,这篇文章都将为你提供有价值的见解和技巧。
|
20天前
|
Java 程序员
Java编程中的异常处理:从基础到高级
在Java的世界中,异常处理是代码健壮性的守护神。本文将带你从异常的基本概念出发,逐步深入到高级用法,探索如何优雅地处理程序中的错误和异常情况。通过实际案例,我们将一起学习如何编写更可靠、更易于维护的Java代码。准备好了吗?让我们一起踏上这段旅程,解锁Java异常处理的秘密!
|
17天前
|
Java
Java 异常处理:11 个异常处理最佳实践
本文深入探讨了Java异常处理的最佳实践,包括早抛出晚捕获、只捕获可处理异常、不忽略异常、抛出具体异常、正确包装异常、记录或抛出异常但不同时执行、不在finally中抛出异常、避免用异常控制流程、使用模板方法减少重复代码、抛出与方法相关的异常及异常处理后清理资源等内容,旨在提升代码质量和可维护性。
|
20天前
|
安全 Java 数据库连接
Java中的异常处理:理解与实践
在Java的世界里,异常处理是维护代码健壮性的守门人。本文将带你深入理解Java的异常机制,通过直观的例子展示如何优雅地处理错误和异常。我们将从基本的try-catch结构出发,探索更复杂的finally块、自定义异常类以及throw关键字的使用。文章旨在通过深入浅出的方式,帮助你构建一个更加稳定和可靠的应用程序。
30 5
|
18天前
|
Java 程序员
深入理解Java异常处理机制
Java的异常处理是编程中的一块基石,它不仅保障了代码的健壮性,还提升了程序的可读性和可维护性。本文将深入浅出地探讨Java异常处理的核心概念、分类、处理策略以及最佳实践,旨在帮助读者建立正确的异常处理观念,提升编程效率和质量。
|
19天前
|
Java 开发者 UED
深入探索Java中的异常处理机制##
本文将带你深入了解Java语言中的异常处理机制,包括异常的分类、异常的捕获与处理、自定义异常的创建以及最佳实践。通过具体实例和代码演示,帮助你更好地理解和运用Java中的异常处理,提高程序的健壮性和可维护性。 ##
43 2
|
19天前
|
Java 开发者
Java中的异常处理机制深度剖析####
本文深入探讨了Java语言中异常处理的重要性、核心机制及其在实际编程中的应用策略,旨在帮助开发者更有效地编写健壮的代码。通过实例分析,揭示了try-catch-finally结构的最佳实践,以及如何利用自定义异常提升程序的可读性和维护性。此外,还简要介绍了Java 7引入的多异常捕获特性,为读者提供了一个全面而实用的异常处理指南。 ####
39 2
|
19天前
|
Java 开发者
Java 中的异常处理:不仅仅是 try-catch
在Java的世界里,异常处理是代码的守护神,它保护着程序不会因为意外错误而崩溃。但异常处理远不止try-catch那么简单。本文将深入探讨Java的异常处理机制,从基本的try-catch到更复杂的自定义异常和finally块的使用,带你理解如何在Java中优雅地处理错误。
50 1
|
22天前
|
Java 程序员 UED
深入理解Java中的异常处理机制
本文旨在揭示Java异常处理的奥秘,从基础概念到高级应用,逐步引导读者掌握如何优雅地管理程序中的错误。我们将探讨异常类型、捕获流程,以及如何在代码中有效利用try-catch语句。通过实例分析,我们将展示异常处理在提升代码质量方面的关键作用。
31 3
|
17天前
|
Java API 开发者
深入理解Java中的异常处理机制
本文探讨了Java编程语言中异常处理的核心概念,包括异常类型、异常捕获与抛出、以及最佳实践。通过分析常见的异常场景和处理策略,旨在帮助开发者更好地理解和运用异常处理机制,提高代码的健壮性和可维护性。文章不仅涵盖了基本的try-catch结构,还深入讨论了自定义异常的创建与使用,以及finally块的重要性和应用。此外,还将介绍一些高级技巧,如多异常捕获和嵌套异常处理,为读者提供全面的技术指导。
68 0