@Async使用记录

Before:

1号

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

 2号

@Async
@Override
public ApiResult<Boolean> 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<Boolean> 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号有任务影响 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值