记录定时器quartz创建定时任务出现异常,导致项目无法启动

今天因为linux服务器部署问题,就重新搭建了数据库的环境并把本地后台代码重新打了个包放上去,结果服务器还是没部署好,本地倒是启动不了了,就很懵逼。毕竟我又没改代码,怎么还连服务器都启动不了了。后面才发现是linux上数据库的问题。也是我基础薄弱,对这块完全不了解,现在就碰到任何错误都记录一下,避免再犯

异常信息: Exception encountered during context initialization - cancelling refresh attempt: org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name ‘scheduleJobController’: Unsatisfied dependency expressed through field ‘scheduleJobService’; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name ‘scheduleJobService’: Invocation of init method failed; nested exception is com.yiqi.common.exception.RRException: 创建定时任务失败

熟悉了定时器,再回头看之前的问题,其实我们按照上面给的异常信息去定位是很简单的,定位到抛出异常的地方,然后找到了原因:项目项目启动时会初始化定时器,但是它数据库里的两个方法是不存在的(大概率被删除了),就会初始化失败,这里代码逻辑有点问题,明明是暂停状态的方法也同样先读取启动然后再暂停,我是觉得如果是暂停状态的任务,直接就可以不读取了。
这里我是直接删了数据库里的两个方法解决的。
在这里插入图片描述
 
 
另外我在这里还出现了一个问题,就是大小写表名的情况,windows的mysql默认表名都是小写的,而项目所在的linux插入表时是区分大小写的,这里定时器用到了一些表就是大写表名,数据库如果不注意操作,就可能发生表找不到的情况。
 
 

下面是原来的文章,也留着就当记录自己的成长
2019.9.27

异常信息: Exception encountered during context initialization - cancelling
refresh attempt:
org.springframework.beans.factory.UnsatisfiedDependencyException:
Error creating bean with name ‘scheduleJobController’: Unsatisfied
dependency expressed through field ‘scheduleJobService’; nested
exception is org.springframework.beans.factory.BeanCreationException:
Error creating bean with name ‘scheduleJobService’: Invocation of init
method failed; nested exception is
com.yiqi.common.exception.RRException: 创建定时任务失败
解决办法: 清空以下4个表
qrtz_blob_triggers; qrtz_cron_triggers ; qrtz_triggers ;
qrtz_job_details; 不过我直接把所有定时器相关表都删了,重新导入了公司框架里的定时器那块sql。

不过最后也没能知道出错的原因和细节,只是单纯的解决了而已,等以后熟悉了定时器可能才会明白吧

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
实现定时任务可以使用Quartz框架,结合Spring MVC进行整合。下面是具体步骤: 1. 引入依赖 在pom.xml中添加依赖: ``` <dependency> <groupId>org.quartz-scheduler</groupId> <artifactId>quartz</artifactId> <version>2.3.0</version> </dependency> ``` 2. 配置Quartz 在Spring的配置文件中添加Quartz的配置,如下: ``` <!--配置Quartz--> <bean id="scheduler" class="org.springframework.scheduling.quartz.SchedulerFactoryBean"> <property name="dataSource" ref="dataSource"/> <property name="quartzProperties"> <props> <prop key="org.quartz.scheduler.instanceName">QuartzScheduler</prop> <prop key="org.quartz.scheduler.instanceId">AUTO</prop> <prop key="org.quartz.scheduler.skipUpdateCheck">true</prop> <prop key="org.quartz.scheduler.jmx.export">true</prop> <prop key="org.quartz.jobStore.class">org.quartz.impl.jdbcjobstore.JobStoreTX</prop> <prop key="org.quartz.jobStore.driverDelegateClass">org.quartz.impl.jdbcjobstore.StdJDBCDelegate</prop> <prop key="org.quartz.jobStore.dataSource">myDS</prop> <prop key="org.quartz.jobStore.tablePrefix">QRTZ_</prop> <prop key="org.quartz.jobStore.isClustered">false</prop> <prop key="org.quartz.threadPool.class">org.quartz.simpl.SimpleThreadPool</prop> <prop key="org.quartz.threadPool.threadCount">10</prop> <prop key="org.quartz.dataSource.myDS.driver">com.mysql.jdbc.Driver</prop> <prop key="org.quartz.dataSource.myDS.URL">jdbc:mysql://localhost:3306/quartz?useUnicode=true&characterEncoding=UTF-8&autoReconnect=true</prop> <prop key="org.quartz.dataSource.myDS.user">root</prop> <prop key="org.quartz.dataSource.myDS.password">123456</prop> <prop key="org.quartz.dataSource.myDS.maxConnections">30</prop> </props> </property> <property name="autoStartup" value="true"/> <property name="startupDelay" value="5"/> </bean> ``` 这里配置了Quartz的数据源,使用的是MySQL数据库。 3. 编写定时任务 创建一个类,实现Quartz的Job接口,如下: ``` public class MyJob implements Job { @Override public void execute(JobExecutionContext context) throws JobExecutionException { System.out.println("定时任务执行了"); } } ``` 4. 配置定时任务 在Spring的配置文件中添加对定时任务的配置,如下: ``` <!-- 配置定时任务 --> <bean id="myJobDetail" class="org.springframework.scheduling.quartz.JobDetailFactoryBean"> <property name="jobClass" value="com.example.MyJob"/> </bean> <bean id="myJobTrigger" class="org.springframework.scheduling.quartz.CronTriggerFactoryBean"> <property name="jobDetail" ref="myJobDetail"/> <property name="cronExpression" value="0/5 * * * * ?"/> </bean> <bean class="org.springframework.scheduling.quartz.SchedulerFactoryBean"> <property name="triggers"> <list> <ref bean="myJobTrigger"/> </list> </property> <property name="schedulerContextAsMap"> <map> <entry key="key1" value="value1"/> <entry key="key2" value="value2"/> </map> </property> <property name="schedulerListeners"> <list> <bean class="org.springframework.scheduling.quartz.JobListenerFactoryBean"> <property name="name" value="jobListener"/> </bean> </list> </property> </bean> ``` 这里配置了一个每5秒执行一次的定时任务。 5. 启动定时任务启动Spring的时候,定时任务会自动启动。也可以在代码中手动启动定时任务,如下: ``` @Autowired private Scheduler scheduler; /** * 启动定时任务 */ public void startJob() throws SchedulerException { scheduler.start(); } ``` 至此,一个使用Spring MVC和Quartz实现的定时任务就完成了。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值