Обнаружен недопустимый метод @Scheduled 'processNotifications': выражение Cron должно состоять из 6 полей (1 находится в "# {@ getConfigRetryValue}") - PullRequest
0 голосов
/ 29 мая 2020

Я конвертирую сборку муравья в сборку градиента. Внезапно не работает @schedule, который использовался для настройки из xml. Я пытаюсь инициализировать метод для получения значений из xml. Я пробовал конфигурацию

xml следующим образом

<interface name="appnotification">      
        <property name="retry_interval" value="0 0/5 * * * ?" /> <!-- every 5 minutes -->
</interface>

java файл выглядит следующим образом

@Component
@EnableScheduling
public class Task {
private static final String INTERFACE_NAME = "appnotification";
@Bean
    public String getConfigRetryValue() {
        Map interfaceProps = Config.getInterfaceProperties(INTERFACE_NAME);     
        return (String) interfaceProps.getOrDefault("retry_interval", DELAY_TIME_IN_MINS);
    }
@Scheduled(cron = "#{@getConfigRetryValue}")
public void processNoti() {}
}

ошибка выглядит следующим образом

Caused by: org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'Task' defined in URL [jar:file:abc.jar!/abc/report/Task.class]: Initialization of bean failed; nested exception is java.lang.IllegalStateException: Encountered invalid @Scheduled method 'processNotifications': Cron expression must consist of 6 fields (found 1 in "#{@getConfigRetryValue}")
    at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:529)
    at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:458)
    at org.springframework.beans.factory.support.AbstractBeanFactory$1.getObject(AbstractBeanFactory.java:293)
    at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:223)
    at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:290)
    at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:191)
    at org.springframework.beans.factory.support.DefaultListableBeanFactory.findAutowireCandidates(DefaultListableBeanFactory.java:921)
    at org.springframework.beans.factory.support.DefaultListableBeanFactory.doResolveDependency(DefaultListableBeanFactory.java:864)
    at org.springframework.beans.factory.support.DefaultListableBeanFactory.resolveDependency(DefaultListableBeanFactory.java:779)
    at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor$AutowiredFieldElement.inject(AutowiredAnnotationBeanPostProcessor.java:503)
    ... 41 more
Caused by: java.lang.IllegalStateException: Encountered invalid @Scheduled method 'processNotifications': Cron expression must consist of 6 fields (found 1 in "#{@getConfigRetryValue}")
    at org.springframework.scheduling.annotation.ScheduledAnnotationBeanPostProcessor.processScheduled(ScheduledAnnotationBeanPostProcessor.java:300)
    at org.springframework.scheduling.annotation.ScheduledAnnotationBeanPostProcessor.access$000(ScheduledAnnotationBeanPostProcessor.java:76)
    at org.springframework.scheduling.annotation.ScheduledAnnotationBeanPostProcessor$1.doWith(ScheduledAnnotationBeanPostProcessor.java:164)
    at org.springframework.util.ReflectionUtils.doWithMethods(ReflectionUtils.java:495)
    at org.springframework.util.ReflectionUtils.doWithMethods(ReflectionUtils.java:473)
    at org.springframework.scheduling.annotation.ScheduledAnnotationBeanPostProcessor.postProcessAfterInitialization(ScheduledAnnotationBeanPostProcessor.java:160)
    at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.applyBeanPostProcessorsAfterInitialization(AbstractAutowireCapableBeanFactory.java:409)
    at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.initializeBean(AbstractAutowireCapableBeanFactory.java:1520)
    at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:521)
    ... 50 more

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...