xxl-job使用遇到的问题(二)

关联阅读 xxl-job使用遇到的问题(一)

1、问题现象

最近有个老定时任务迁移到xxl-job的时候,遇到一个小问题。虽然很快解决,但是还是有必要记录一下~

job迁移的时候,在执行方法上标记@XxlJob("test"),然后在管理控制台上,添加任务,点击执行一次的时候,调度日志提示

>>>>>>>>>>>触发调度<<<<<<<<<<<

触发调度:

address:http://10.25.31.45:9999/

code:500

msg:job handler [test] not found.

检查了下代码,没啥问题。注解加了,XxlJobSpringExecutor也有,properties配置也ok,为啥提示找不到呢?

大致代码也贴一下

public interface ITestJob {
void method1();
} @Service
public class TestJobImpl implements ITestJob { @XxlJob("test")
public ReturnT<String> demoJobHandler() throws Exception {
// job业务逻辑【历史代码】
return ReturnT.SUCCESS;
} // 历史代码方法
@Override
@Async
public void method1() {
// 历史代码逻辑
}
}

其实就是在历史代码的基础上,改了下方法返回值,加了个@XxlJob("test")注解。其他没动

2、排查

既然提示找不到job handler,那问题肯定是出在客户端了。

前面阅读源码的时候,已经看过,@XxlJob注解的解析是在 XxlJobSpringExecutor类里面。快读看了下这个类,重点看了下initJobHandlerMethodRepository方法

private void initJobHandlerMethodRepository(ApplicationContext applicationContext) {
if (applicationContext == null) {
return;
}
// init job handler from method
String[] beanDefinitionNames = applicationContext.getBeanNamesForType(Object.class, false, true);
for (String beanDefinitionName : beanDefinitionNames) {
Object bean = applicationContext.getBean(beanDefinitionName); Map<Method, XxlJob> annotatedMethods = null; // referred to :org.springframework.context.event.EventListenerMethodProcessor.processBean
try {
annotatedMethods = MethodIntrospector.selectMethods(bean.getClass(),
new MethodIntrospector.MetadataLookup<XxlJob>() {
@Override
public XxlJob inspect(Method method) {
return AnnotatedElementUtils.findMergedAnnotation(method, XxlJob.class);
}
});
} catch (Throwable ex) {
logger.error("xxl-job method-jobhandler resolve error for bean[" + beanDefinitionName + "].", ex);
}
if (annotatedMethods==null || annotatedMethods.isEmpty()) {
continue;
} ...... }

在这块加个断点看看,果然拿到的 annotatedMethods 是空的,难怪提示找不到呢!

3、原因

上面的demoJobHandler方法头上标记了注解的,为什么annotatedMethods是空的呢?

这是因为下面这行代码取到的bean,不是TestJobImpl这个类

Object bean = applicationContext.getBean(beanDefinitionName);

而是一个代理类,并且是jdk的动态代理的类。

jdk动态代理,啥特性?

嗯,基于接口的~~,接口里面只申明了一个方法 method1,那【MethodIntrospector.selectMethods】肯定找不到有XxlJob注解的方法了!

3.1、 解决办法

知道了这一点,那就好解决了。

可供参考的解决办法:

方法一、把job这个方法单独拎出来

方法二、去掉接口,让Spring使用cglib的代理。这样取到的代理类就包含2个方法了,就可以找到有注解的那个方法了

方法三、如果上面2个都不想改,那就在接口里面申明一个demoJobHandler方法,并且在接口方法申明上标记@XxlJob("test")注解

最新文章

  1. Spire.DOC生成表格测试
  2. linux系统的学习
  3. TimeQuest 静态时序分析 基本概论
  4. js里cookie操作
  5. compass电子罗盘
  6. 解决float浮动带来的父元素高度没有的问题---清除浮动
  7. OpenCV Linux 安装 Make出错
  8. open(/dev/ietctl, O_RDWR) 参数含义(转载)
  9. 关于shell脚本编程的10个最佳实践
  10. [Usaco2008 Nov]Guarding the Farm 保卫牧场[DFS]
  11. win7电脑蓝牙 耳机
  12. centos7 openssl 生成证书给自己使用
  13. docker network基础
  14. Appium 学习二:切换Webview
  15. 使用Selenium和openCV对HTML5 canvas游戏进行自动化功能测试(一)
  16. 【python】python常用函数
  17. Spring Cloud Zuul的一个坑
  18. sqlplus 格式化一例
  19. 设计好玩的3D文字效果
  20. Spring中基于Java的配置@Configuration和@Bean用法

热门文章

  1. Cobalt Strike使用教程一
  2. IDEA使用JFX的相关问题
  3. Go-08-函数与指针
  4. GO-04-变量
  5. 现代操作系统原书第3版.mobi
  6. Day01_09_数据类型
  7. 代码安全丨第二期:URL重定向(跳转)漏洞
  8. 10行C++代码实现高性能HTTP服务
  9. 解决github不能访问的问题
  10. 473. Matchsticks to Square