博客
关于我
SpringCloud Alibaba微服务实战二十四 - SpringCloud Gateway的全局异常处理
阅读量:629 次
发布时间:2019-03-14

本文共 2525 字,大约阅读时间需要 8 分钟。

全局异常处理与微服务网关异常拦截

在微服务架构中,传统的全局异常处理方式可能无法满足所有场景,特别是在网关层面遇到的异常。以下将详细讲解如何实现全局异常处理,并解决网关层面异常的处理问题。

全局异常处理

在单体Spring Boot项目中,全局异常处理可以通过配置@RestControllerAdvice@ExceptionHandler来实现统一处理。这种方式适用于项目内部的异常捕捉和处理,但在微服务架构中,尤其是在网关层面遇到的异常无法被捕获,因此需要额外处理。

以下是一个典型的全局异常处理示例:

@Slf4j@RestControllerAdvicepublic class RestExceptionHandler {    @ExceptionHandler(Exception.class)    @ResponseStatus(HttpStatus.INTERNAL_SERVER_ERROR)    public ResultData exception(Exception e) {        log.error("全局异常信息 ex={}", e.getMessage(), e);        return ResultData.fail(ReturnCode.RC500.getCode(), e.getMessage());    }}

网关层面异常处理

在微服务架构中,网关作为入口点,常常会遇到无法被传统异常处理机制捕获的异常,例如JWT解析失败或服务下线等。为了解决这些问题,我们需要自定义异常处理逻辑。

自定义异常处理器

我们可以定义一个全局异常处理器,继承自DefaultErrorWebExceptionHandler,并重写handler()方法,返回自定义的响应格式。

@Slf4j@Order(-1)@Configuration@RequiredArgsConstructorpublic class GlobalErrorWebExceptionHandler implements ErrorWebExceptionHandler {    private final ObjectMapper objectMapper;    @Override    public Mono
handle(ServerWebExchange exchange, Throwable ex) { ServerHttpResponse response = exchange.getResponse(); if (response.isCommitted()) { return Mono.error(ex); } response.getHeaders().setContentType(MediaType.APPLICATION_JSON); if (ex instanceof ResponseStatusException) { response.setStatusCode(((ResponseStatusException) ex).getStatus()); } return response.writeWith(Mono.fromSupplier(() -> { try { return objectMapper.writeValueAsBytes(ResultData.fail(500, ex.getMessage())); } catch (JsonProcessingException e) { log.error("Error writing response", ex); return new byte[0]; } })); }}

解决方案

  • 自定义异常处理类:创建一个继承自DefaultErrorWebExceptionHandler的类,重写handler()方法,返回自定义的响应格式。
  • 配置类:定义一个配置类,替换默认的异常处理器为自定义的类。
  • 响应格式:确保返回的数据格式符合前端约定的格式,例如:
  • @Data@ApiModel(value = "统一返回结果封装", description = "接口返回统一结果")public class ResultData {    @ApiModelProperty(value = "状态码")    private int status;    @ApiModelProperty(value = "响应信息")    private String message;    @ApiModelProperty(value = "后端返回结果")    private T data;    @ApiModelProperty(value = "后端响应状态")    private boolean success;    @ApiModelProperty(value = "响应时间戳")    private long timestamp;    public ResultData() {        this.timestamp = System.currentTimeMillis();    }}

    测试结果

    通过以上配置,可以实现网关层面的异常拦截,并返回符合预期的数据格式。测试结果如下:

    • JWT解析异常:返回状态码500,消息为"无法解析访问令牌"。
    • 服务下线异常:返回状态码503,消息为"服务不可用"。

    这种方式可以有效处理网关层面无法被传统异常处理机制捕获的异常,确保返回格式一致性和可读性。

    希望以上内容对您有所帮助,欢迎在评论区留言交流!

    转载地址:http://tucoz.baihongyu.com/

    你可能感兴趣的文章
    OpenCV学堂 | YOLOv8实战 | 荧光显微镜细胞图像检测
    查看>>
    OpenCV官方文档 理解k - means聚类
    查看>>
    OpenCV探索
    查看>>
    OpenCV环境搭建(一)
    查看>>
    openCV目标识别 目标跟踪 YOLO5深度学习 Python 计算机视觉 计算机毕业设计 源码下载
    查看>>
    opencv笔记(1):图像缩放
    查看>>
    opencv笔记(二十四)——得到轮廓之后找到凸包convex hull
    查看>>
    OpenCV计算点到直线的距离 数学法
    查看>>
    Opencv识别图中人脸
    查看>>
    OpenCV读写avi、mpeg文件
    查看>>
    opencv面向对象设计初探
    查看>>
    OpenCV(1)读写图像
    查看>>
    OpenCV:不规则形状区域中每种颜色的像素数?
    查看>>
    OpenCV:概念、历史、应用场景示例、核心模块、安装配置
    查看>>
    OpenDaylight融合OpenStack架构分析
    查看>>
    openEuler Summit 2022 成功举行,开启全场景创新新时代
    查看>>
    openEuler 正式开放:推动计算多样化时代的到来
    查看>>
    OpenEuler23.03欧拉系统_安装瀚高数据库企业版6.0.4_踩坑_安装以后系统无法联网_启动ens33网卡---国产瀚高数据库工作笔记002
    查看>>
    OpenFeign源码学习
    查看>>
    OpenFeign组件声明式服务调用
    查看>>