Ошибка NoClassDefFoundError: net/javacrumbs/shedlock/core/LockProvider

#java #spring #scheduled-tasks #shedlock

#java #весна #запланированные задачи #shedlock

Вопрос:

Мы пытаемся разработать пакет cron. Я настроил аннотацию @SchedulerLock, но они не работают. Этот код, вероятно, работает с более чем 1 узлом. Я прочитал в Github, что @SchedulerLock может работать с этими реализациями, но не работать. Я тоже пытался, @tryLock, но это тоже не сработало. Мне нужна помощь для запуска этого кода, потому что я не знаю, в чем ошибка в коде. Спасибо!

 @SpringBootApplication
@EnableAutoConfiguration
@EnableCaching
public class AppExportacionDatos {

    public static void main(String[] args) {
        SpringApplication.run(AppExportacionDatos.class, args);
    }

}

 
 @Configuration
@EnableScheduling
@EnableSchedulerLock(defaultLockAtMostFor = "540m")
public class CommonConfig {
    
    @Bean
    public LockProvider lockProvider(DataSource dataSource) {
        return new JdbcTemplateLockProvider(
            JdbcTemplateLockProvider.Configuration.builder()
            .withJdbcTemplate(new JdbcTemplate(dataSource))
            .usingDbTime() // Works on Postgres, MySQL, MariaDb, MS SQL, Oracle, DB2, HSQL and H2
            .build()
        );
    }
    @Bean
    public MessageSource messageSource() {
        ReloadableResourceBundleMessageSource messageSource = new ReloadableResourceBundleMessageSource();
        messageSource.setBasename("classpath:i18n/messages");
        messageSource.setDefaultEncoding("ISO-8859-1");
        return messageSource;
    }
    @Bean
    public LocalValidatorFactoryBean getValidator() {
        LocalValidatorFactoryBean bean = new LocalValidatorFactoryBean();
        bean.setValidationMessageSource(messageSource());
        return bean;
    }

}
 
 @Component
public class BatchTasks {

    
//  @Scheduled(cron = "${cronExpression}")
    @Scheduled(fixedDelay = 60000)
    @SchedulerLock(name = "scheduledTaskName") 
    public void generarFicheroExportacion() {
        ................
    }
}

 
         <dependency>
            <groupId>net.javacrumbs.shedlock</groupId>
            <artifactId>shedlock-spring</artifactId>
            <version>4.20.0</version>
        </dependency>
        <dependency>
            <groupId>net.javacrumbs.shedlock</groupId>
            <artifactId>shedlock-provider-jdbc-template</artifactId>
            <version>4.20.0</version>
        </dependency>

 

Исключением при запуске приложения являются:

 Caused by: java.lang.ClassNotFoundException: net.javacrumbs.shedlock.core.LockProvider
    at java.net.URLClassLoader.findClass(URLClassLoader.java:382) ~[?:1.8.0_281]
    at java.lang.ClassLoader.loadClass(ClassLoader.java:418) ~[?:1.8.0_281]
    at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:355) ~[?:1.8.0_281]
    at java.lang.ClassLoader.loadClass(ClassLoader.java:351) ~[?:1.8.0_281]
    at java.lang.Class.forName0(Native Method) ~[?:1.8.0_281]
    at java.lang.Class.forName(Class.java:348) ~[?:1.8.0_281]
    at org.springframework.boot.devtools.restart.classloader.RestartClassLoader.loadClass(RestartClassLoader.java:144) ~[spring-boot-devtools-2.4.0.jar:2.4.0]
    at java.lang.ClassLoader.loadClass(ClassLoader.java:351) ~[?:1.8.0_281]
    at java.lang.Class.getDeclaredMethods0(Native Method) ~[?:1.8.0_281]
    at java.lang.Class.privateGetDeclaredMethods(Class.java:2701) ~[?:1.8.0_281]
    at java.lang.Class.getDeclaredMethods(Class.java:1975) ~[?:1.8.0_281]
    at org.springframework.util.ReflectionUtils.getDeclaredMethods(ReflectionUtils.java:463) ~[spring-core-5.3.1.jar:5.3.1]
    ... 26 more

 

Комментарии:

1. Из трассировки стека кажется, что просто spring-devtools не удалось выполнить горячую перезагрузку. Вы пытались перезапустить свое приложение (остановить и запустить снова)?