• @Async使用记录


    Before:

    1号

    @ApiOperation("保存日志")
    @PostMapping("/saveLog")
    @Override
    public ApiResult saveLog(@RequestBody Req req) {
        return logManager.saveLog(req);
    } 

     2号

    @Async
    @Override
    public ApiResult saveLog(Req req) {
        logService.saveBusinessLog();
        return ApiResult.success(Boolean.TRUE);
    }
    

     3号

    @RestControllerAdvice
    @Order(-2147483628)
    @ConditionalOnProperty(prefix = "response.wrap",name = "enabled",matchIfMissing = true)
    @Slf4j
    public class ResponseWrapHandler implements ResponseBodyAdvice {
        @Override
        public boolean supports(MethodParameter returnType, Class converterType) {
            return true;
        }
    
        @Override
        public Object beforeBodyWrite(Object body, MethodParameter returnType, MediaType selectedContentType, Class selectedConverterType, ServerHttpRequest request, ServerHttpResponse response) {
            if (body instanceof ApiResult
                    ||returnType.hasMethodAnnotation(SkipWrap.class)
                    ||body instanceof String
                    ||HttpContext.isFeignRequest()
                    || PathMatchUtil.match(MainClassConstant.SWAGGER_URL, HttpContext.getRequest().getServletPath())
                    ){
                return body;
            }
            return ApiResult.success(body);
        }
    }
    

    Before结果:

    此时,1号返回的是:

    {

        "success": true,

        "code": "200",

        "msg": "请求成功",

        "traceId": "",

        "data": null

    }

     

     After:

    @ApiOperation("保存日志")

    @PostMapping("/saveLog")

    @Override

    public ApiResult saveLog(@RequestBody Req req) {

         logManager.saveLog(req);

         return ApiResult.success(Boolean.TRUE);

    After结果:

    {

        "success": true,

        "code": "200",

        "msg": "请求成功",

        "traceId": "",

        "data": true

    }

     

    代码执行顺序:

    1号 -》3号 -》2号

    2号中抛出异常也不会对1号有任务影响 

  • 相关阅读:
    如何在Excel中自动创建报告 Excel中自动创建报告的方法
    CSRF和XSS是什么?有什么区别?
    【CPU设计实战】简单流水线CPU设计
    科赫曲线
    怎样P漫画脸?这三个简单方法分享给你
    express学习8-app.use方法
    Spring Boot 多环境配置
    飞书API 2-1:如何通过 API 创建文件夹?
    华为OD机考算法题:找终点
    非常经典的Oracle基础知识
  • 原文地址:https://blog.csdn.net/chenwen0326/article/details/126873035