web-dev-qa-db-fra.com

Le planificateur ne fonctionne pas dans Spring Boot

J'ai créé une application Spring Boot. J'ai configuré ma classe qui contient la méthode du planificateur startService(). Voici mon code:

Classe de service:

package com.mk.service;  
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.scheduling.annotation.Scheduled;
import org.springframework.stereotype.Component;

import com.mk.envers.model.BossExtChange;
import com.mk.envers.model.BossExtChangeRepository;

@Component
public class EnverseDemoService {

    @Autowired
    BossExtChangeRepository bossExtChangeRepository;

    @Scheduled(fixedRate = 30000)
    public void startService() {
        System.out.println("Calling startService()");
        BossExtChange bossExtChange = bossExtChangeRepository.findById(5256868L);
        System.out.println("bossExtChange.getDescription()--->"+bossExtChange.getDescription());
        System.out.println("Ending startService()");
    }
}

Classe principale:

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.context.annotation.PropertySource;
import org.springframework.scheduling.annotation.EnableScheduling;

@SpringBootApplication
@EnableScheduling
@PropertySource("classpath:application.properties")
public class EnverseDemoApplication {

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

J'ai annoté la classe comme @Component Et aussi la méthode comme @Scheduled(fixedRate = 30000) qui fonctionnera comme un planificateur. Mais lors de l'exécution de l'application en tant que Spring Boot, le planificateur ne se déclenche pas. La console affiche le message ci-dessous:

2016-02-03 10:56:47.708  INFO 10136 --- [           main] o.s.j.e.a.AnnotationMBeanExporter        : Registering beans for JMX exposure on startup 
2016-02-03 10:56:47.721  INFO 10136 --- [           main] com.mk.envers.EnverseDemoApplication     : Started EnverseDemoApplication in 3.231 seconds (JVM running for 3.623)
2016-02-03 10:56:47.721  INFO 10136 --- [       Thread-2] s.c.a.AnnotationConfigApplicationContext : Closing org.springframework.context.annotation.AnnotationConfigApplicationContext@49e202ad: startup date [Wed Feb 03 10:56:44 IST 2016]; root of context hierarchy
2016-02-03 10:56:47.721  INFO 10136 --- [       Thread-2] o.s.j.e.a.AnnotationMBeanExporter        : Unregistering JMX-exposed beans on shutdown 
2016-02-03 10:56:47.736  INFO 10136 --- [       Thread-2] j.LocalContainerEntityManagerFactoryBean : Closing JPA EntityManagerFactory for persistence unit 'default'

Est-ce que quelqu'un peut m'aider s'il vous plait.

14
Mohith Kumar

J'ai finalement pu résoudre le problème ci-dessus, j'ai changé le package de ma classe de service EnverseDemoService from package com.mk.service; à com.mk.envers.service;. En effet, si la classe de configuration principale EnverseDemoApplication est présente dans le package com.mk.envers. Toutes les autres classes de l'application de démarrage doivent figurer dans le package éligible. Eg: com.mk.envers.*;

9
Mohith Kumar

Peut-être pouvez-vous résoudre ce problème en ajoutant l'annotation @ ComponentScan dans le fichier de configuration

@SpringBootApplication
@EnableScheduling
@ComponentScan(basePackages = "com.mk.service")
@PropertySource("classpath:application.properties")
public class EnverseDemoApplication {

    public static void main(String[] args) {
        SpringApplication.run(EnverseDemoApplication.class, args);
    }
}
22
Federico Traiman

Il faut que vous ayez oublié d'ajouter l'annotation @EnableScheduling dans votre classe d'application.

public static void main(String[] args) {
        context = SpringApplication.run(YouApplication.class, args);
    }
5
Pravin