Skip to content
项目
群组
代码片段
帮助
正在加载...
登录
切换导航
X
XXL-JOB
项目
项目
详情
活动
周期分析
仓库
仓库
文件
提交
分支
标签
贡献者
分枝图
比较
统计图
议题
0
议题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程
统计图
Wiki
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
分枝图
统计图
创建新议题
作业
提交
议题看板
打开侧边栏
靳帅
XXL-JOB
Commits
51bfaa41
提交
51bfaa41
authored
1月 11, 2016
作者:
xueli.xue
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
1、调度重启后,取消补偿遗失调度;
2、延迟启动调度器; 3、支持调度非并发执行,默认并发(需要扩大线程数);
上级
2540860e
隐藏空白字符变更
内嵌
并排
正在显示
3 个修改的文件
包含
15 行增加
和
4 行删除
+15
-4
DynamicSchedulerUtil.java
...main/java/com/xxl/job/core/util/DynamicSchedulerUtil.java
+3
-3
applicationcontext-trigger-db.xml
...dmin/src/main/resources/applicationcontext-trigger-db.xml
+2
-1
DemoJobBean.java
...le/src/main/java/com/xxl/job/service/job/DemoJobBean.java
+10
-0
没有找到文件。
xxl-job-admin/src/main/java/com/xxl/job/core/util/DynamicSchedulerUtil.java
浏览文件 @
51bfaa41
...
@@ -104,8 +104,8 @@ public final class DynamicSchedulerUtil implements InitializingBean {
...
@@ -104,8 +104,8 @@ public final class DynamicSchedulerUtil implements InitializingBean {
return
false
;
return
false
;
}
}
// CronTrigger : TriggerKey + cronExpression
// CronTrigger : TriggerKey + cronExpression
// withMisfireHandlingInstructionDoNothing 忽略掉调度终止过程中忽略的调度
CronScheduleBuilder
cronScheduleBuilder
=
CronScheduleBuilder
.
cronSchedule
(
cronExpression
);
CronScheduleBuilder
cronScheduleBuilder
=
CronScheduleBuilder
.
cronSchedule
(
cronExpression
)
.
withMisfireHandlingInstructionDoNothing
()
;
CronTrigger
cronTrigger
=
TriggerBuilder
.
newTrigger
().
withIdentity
(
triggerKey
).
withSchedule
(
cronScheduleBuilder
).
build
();
CronTrigger
cronTrigger
=
TriggerBuilder
.
newTrigger
().
withIdentity
(
triggerKey
).
withSchedule
(
cronScheduleBuilder
).
build
();
// JobDetail : jobClass
// JobDetail : jobClass
...
@@ -131,7 +131,7 @@ public final class DynamicSchedulerUtil implements InitializingBean {
...
@@ -131,7 +131,7 @@ public final class DynamicSchedulerUtil implements InitializingBean {
boolean
result
=
false
;
boolean
result
=
false
;
if
(
scheduler
.
checkExists
(
triggerKey
))
{
if
(
scheduler
.
checkExists
(
triggerKey
))
{
// CronTrigger : TriggerKey + cronExpression
// CronTrigger : TriggerKey + cronExpression
CronScheduleBuilder
cronScheduleBuilder
=
CronScheduleBuilder
.
cronSchedule
(
cronExpression
);
CronScheduleBuilder
cronScheduleBuilder
=
CronScheduleBuilder
.
cronSchedule
(
cronExpression
)
.
withMisfireHandlingInstructionDoNothing
()
;
CronTrigger
cronTrigger
=
TriggerBuilder
.
newTrigger
().
withIdentity
(
triggerKey
).
withSchedule
(
cronScheduleBuilder
).
build
();
CronTrigger
cronTrigger
=
TriggerBuilder
.
newTrigger
().
withIdentity
(
triggerKey
).
withSchedule
(
cronScheduleBuilder
).
build
();
Date
date
=
scheduler
.
rescheduleJob
(
triggerKey
,
cronTrigger
);
Date
date
=
scheduler
.
rescheduleJob
(
triggerKey
,
cronTrigger
);
...
...
xxl-job-admin/src/main/resources/applicationcontext-trigger-db.xml
浏览文件 @
51bfaa41
...
@@ -11,7 +11,8 @@
...
@@ -11,7 +11,8 @@
<bean
id=
"quartzScheduler"
lazy-init=
"false"
class=
"org.springframework.scheduling.quartz.SchedulerFactoryBean"
>
<bean
id=
"quartzScheduler"
lazy-init=
"false"
class=
"org.springframework.scheduling.quartz.SchedulerFactoryBean"
>
<property
name=
"dataSource"
ref=
"dataSource"
/>
<property
name=
"dataSource"
ref=
"dataSource"
/>
<property
name=
"autoStartup"
value=
"true"
/>
<property
name=
"autoStartup"
value=
"true"
/>
<!--自动启动 -->
<property
name=
"startupDelay"
value=
"20"
/>
<!--延时启动 -->
<property
name=
"applicationContextSchedulerContextKey"
value=
"applicationContextKey"
/>
<property
name=
"applicationContextSchedulerContextKey"
value=
"applicationContextKey"
/>
<property
name=
"configLocation"
value=
"classpath:quartz.properties"
/>
<property
name=
"configLocation"
value=
"classpath:quartz.properties"
/>
</bean>
</bean>
...
...
xxl-job-simple/src/main/java/com/xxl/job/service/job/DemoJobBean.java
浏览文件 @
51bfaa41
...
@@ -3,7 +3,9 @@ package com.xxl.job.service.job;
...
@@ -3,7 +3,9 @@ package com.xxl.job.service.job;
import
java.util.HashMap
;
import
java.util.HashMap
;
import
java.util.Map
;
import
java.util.Map
;
import
java.util.Map.Entry
;
import
java.util.Map.Entry
;
import
java.util.concurrent.TimeUnit
;
import
org.quartz.DisallowConcurrentExecution
;
import
org.quartz.JobExecutionContext
;
import
org.quartz.JobExecutionContext
;
import
org.quartz.JobExecutionException
;
import
org.quartz.JobExecutionException
;
import
org.slf4j.Logger
;
import
org.slf4j.Logger
;
...
@@ -14,6 +16,8 @@ import org.springframework.scheduling.quartz.QuartzJobBean;
...
@@ -14,6 +16,8 @@ import org.springframework.scheduling.quartz.QuartzJobBean;
* http job bean
* http job bean
* @author xuxueli 2015-12-17 18:20:34
* @author xuxueli 2015-12-17 18:20:34
*/
*/
@DisallowConcurrentExecution
// 取消并发执行;线程数要多配置几个,否则不生效;
public
class
DemoJobBean
extends
QuartzJobBean
{
public
class
DemoJobBean
extends
QuartzJobBean
{
private
static
Logger
logger
=
LoggerFactory
.
getLogger
(
DemoJobBean
.
class
);
private
static
Logger
logger
=
LoggerFactory
.
getLogger
(
DemoJobBean
.
class
);
...
@@ -33,6 +37,12 @@ public class DemoJobBean extends QuartzJobBean {
...
@@ -33,6 +37,12 @@ public class DemoJobBean extends QuartzJobBean {
}
}
}
}
try
{
TimeUnit
.
SECONDS
.
sleep
(
5
);
}
catch
(
InterruptedException
e
)
{
e
.
printStackTrace
();
}
logger
.
info
(
">>>>>>>>>>> xxl-job run :jobId:{}, group:{}, jobDataMap:{}"
,
logger
.
info
(
">>>>>>>>>>> xxl-job run :jobId:{}, group:{}, jobDataMap:{}"
,
new
Object
[]{
triggerKey
,
triggerGroup
,
jobDataMap
});
new
Object
[]{
triggerKey
,
triggerGroup
,
jobDataMap
});
}
}
...
...
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论