使用环绕通知监测定时器任务

/**
 * 设置拦截的路径和排除的路径
 */
@Pointcut("@annotation(io.lenovo.clogistics.bms.common.util.TaskName)")
public void pointCut() {
}
//通过环绕通知获取程序信息,用的是自定义注解命名每个定时器的名称,因为@Scheduled 不可以有返回值
@Around("pointCut()&&@annotation(taskName)")
public void AroundAdvice1(ProceedingJoinPoint joinPoint, TaskName taskName) {
    CfTaskLogWriteVO cfTaskLog = new CfTaskLogWriteVO();
    cfTaskLog.setBeginTime(new Date());
    cfTaskLog.setName(taskName.name());
    try {
        joinPoint.proceed();
        cfTaskLog.setStatus(0);
        cfTaskLog.setRemark("程序正常");
        cfTaskLog.setEndTime(new Date());
        cfTaskLogService.insertCfTaskLog(cfTaskLog);
    } catch (Throwable e) {
        cfTaskLog.setStatus(1);
        cfTaskLog.setErr(e.getMessage());
        cfTaskLog.setEndTime(new Date());
        cfTaskLog.setRemark("程序运行异常");
        cfTaskLogService.insertCfTaskLog(cfTaskLog);
    }
}

//自定义注解

@Target({ ElementType.METHOD })
@Retention(RetentionPolicy.RUNTIME)
@Documented
public @interface TaskName{
    String name() default "";

}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值