5

我有一个我希望 spring 安排的方法 - 就此而言,我正在使用@Scheduled注释 - 更准确地说,我正在使用 cron 表达式。我的 cron 表达式位于名为 scheduler.properties 的属性文件中。当我将它用作占位符时@Scheduled(cron="${cron}")- 一切都很好;但我想使用 SpEL ( @Scheduled(cron="#{scheduler['cron']}")) ,但它不起作用 - 引发以下异常:java.lang.IllegalArgumentException: cron expression must consist of 6 fields (found 1 in #{scheduler['cron']})

我在这里做错了什么?

编辑: 这是我的属性文件中的 cron 表达式:cron=0 0/1 * * * ?

这是我得到的堆栈跟踪: java.lang.IllegalArgumentException: cron expression must consist of 6 fields (found 1 in #{scheduler['cron']}) at org.springframework.scheduling.support.CronSequenceGenerator.parse(CronSequenceGenerator.java:233) at org.springframework.scheduling.support.CronSequenceGenerator.<init>(CronSequenceGenerator.java:81) at org.springframework.scheduling.support.CronTrigger.<init>(CronTrigger.java:54) at org.springframework.scheduling.support.CronTrigger.<init>(CronTrigger.java:44) at org.springframework.scheduling.config.ScheduledTaskRegistrar.afterPropertiesSet(ScheduledTaskRegistrar.java:188) at org.springframework.scheduling.annotation.ScheduledAnnotationBeanPostProcessor.onApplicationEvent(ScheduledAnnotationBeanPostProcessor.java:209) at org.springframework.scheduling.annotation.ScheduledAnnotationBeanPostProcessor.onApplicationEvent(ScheduledAnnotationBeanPostProcessor.java:1) at org.springframework.context.event.SimpleApplicationEventMulticaster.multicastEvent(SimpleApplicationEventMulticaster.java:97) at org.springframework.context.support.AbstractApplicationContext.publishEvent(AbstractApplicationContext.java:324) at org.springframework.context.support.AbstractApplicationContext.finishRefresh(AbstractApplicationContext.java:929) at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:467) at org.springframework.web.context.ContextLoader.configureAndRefreshWebApplicationContext(ContextLoader.java:384) at org.springframework.web.context.ContextLoader.initWebApplicationContext(ContextLoader.java:283) at org.springframework.web.context.ContextLoaderListener.contextInitialized(ContextLoaderListener.java:111) at org.apache.catalina.core.StandardContext.listenerStart(StandardContext.java:4723) at org.apache.catalina.core.StandardContext$1.call(StandardContext.java:5226) at org.apache.catalina.core.StandardContext$1.call(StandardContext.java:5221) at java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:334) at java.util.concurrent.FutureTask.run(FutureTask.java:166) at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1110) at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:603) at java.lang.Thread.run(Thread.java:722)

第二次编辑: 似乎 spring 正在尝试将以下字符串解析为实际 cron 表达式本身的 cron experssion "#{scheduler['cron']}" insraed。

4

4 回答 4

3

根据错误消息,您的属性文件中的 cron 表达式的值不正确。

它不符合预期的语法。

该值应包含六个字段,看起来像这样。

* 10 * * * *

这是引发此异常的代码

/**
 * Parse the given pattern expression.
 */
private void parse(String expression) throws IllegalArgumentException {
    String[] fields = StringUtils.tokenizeToStringArray(expression, " ");
    if (fields.length != 6) {
        throw new IllegalArgumentException(String.format(""
                + "cron expression must consist of 6 fields (found %d in %s)", fields.length, expression));
    }

可能无法在注释中使用 spEL 将 cron 配置外部化。

替代方法是使用 XML 或使用 cron 表达式。

http://forum.springsource.org/showthread.php?91203-Scheduled-and-externalization-of-configuration-for-fixedDelay-and-fixedRate-problem

于 2012-05-01T07:22:28.137 回答
1

在属性文件中总是这样指定:注意频率之间的空间。

每天早上 9 点运行刷新作业

作业.cron.rate=0 0 9 * * *

示例模式:

* "0 0 * * * *" = the top of every hour of every day.
* "*/10 * * * * *" = every ten seconds.
* "0 0 8-10 * * *" = 8, 9 and 10 o'clock of every day.
* "0 0/30 8-10 * * *" = 8:00, 8:30, 9:00, 9:30 and 10 o'clock every day.
* "0 0 9-17 * * MON-FRI" = on the hour nine-to-five weekdays
* "0 0 0 25 12 ?" = every Christmas Day at midnight

在代码中像这样使用它:

@Scheduled(cron = "${job.cron.rate}")    
public void perform() throws InterruptedException {
}
于 2015-03-20T18:18:05.787 回答
1

我有一个类似的问题并通过读取带有上下文的属性文件来解决它:property-placeholder

<util:properties id="applicationProps" location="/WEB-INF/classes/properties/application.properties" /> **<context:property-placeholder properties-ref="applicationProps" />**

希望它可以帮助某人!

于 2015-11-03T04:20:10.943 回答
0

有用。我花了几天时间弄清楚……但这确实有效。

  1. 您应该像为 JAVA_HOME 等设置环境变量一样。
  2. 关闭你的 IDE。

export cron_scheduler_expression="0 19 21 * * *"

然后重新启动您正在使用的 IDE、Eclipse 或 NetBeans。

@Scheduled(cron = "${cron_scheduler_expression}")
public void runSchedulerTask(){

}
于 2016-09-22T15:06:05.203 回答