Расписание задач с Jax-RS и CDI - PullRequest
0 голосов
/ 03 апреля 2020

Я пытаюсь понять, как управлять запланированными задачами в моем проекте с помощью Jax-RS и CDI. С помощью Spring я легко смог добиться этого с помощью аннотации ThreadPoolTaskScheduler или @Scheduled, и я пытаюсь воспроизвести оба пути безуспешно.

Прежде всего, я использую Wildfly 14, и это похоже на вызывать некоторые проблемы, потому что я попытался ввести @Resource и ManagedScheduledExecutorService и TimerService, но Wildfly выдает исключение отсутствующих зависимостей (но руководство администратора не помогло мне в этом).

Вместо ресурсов для инъекций Я попытался использовать одноэлементный объект, подобный этому:

@Singleton
public class CacheManager {
    private final static Logger log = LogManager.getLogger();

    public CacheManager() {
         log.error("######## Init" + LocalTime.now());
    }

     @Schedule(hour = "*", minute = "*", second = "*/1")
     private void timeout() {
         log.error("######## " + LocalTime.now());
     }

}

Но метод никогда не вызывается.

Так что я не понимаю, чего мне не хватает. Возможно, я неправильно настроил проект, так что это мой pom. xml зависимости:

    <dependency>
        <groupId>com.google.code.gson</groupId>
        <artifactId>gson</artifactId>
        <version>2.8.2</version>
    </dependency>

    <dependency>
        <groupId>com.fasterxml.jackson.core</groupId>
        <artifactId>jackson-databind</artifactId>
        <version>2.10.2</version>
    </dependency>

    <!-- Import the JAX-RS API, we use provided scope as the API is included in JBoss WildFly -->
    <dependency>
        <groupId>org.jboss.resteasy</groupId>
        <artifactId>resteasy-jaxrs</artifactId>
        <version>3.10.0.Final</version>
        <scope>provided</scope>
    </dependency>
    <dependency>
        <groupId>org.jboss.resteasy</groupId>
        <artifactId>jaxrs-api</artifactId>
        <version>3.0.12.Final</version>
        <scope>provided</scope>
    </dependency>
    <dependency>
        <groupId>org.jboss.resteasy</groupId>
        <artifactId>resteasy-multipart-provider</artifactId>
        <version>3.0.12.Final</version>
        <scope>provided</scope>
    </dependency>

    <!-- Import the CDI API, we use provided scope as the API is included in JBoss WildFly -->
    <dependency>
        <groupId>javax.enterprise</groupId>
        <artifactId>cdi-api</artifactId>
        <version>2.0</version>
        <scope>provided</scope>
    </dependency>

    <!-- Import the JSF API, we use provided scope as the API is included in JBoss WildFly -->
    <dependency>
        <groupId>org.jboss.spec.javax.faces</groupId>
        <artifactId>jboss-jsf-api_2.2_spec</artifactId>
        <version>2.2.14</version>
        <scope>provided</scope>
    </dependency>

    <dependency>
        <groupId>org.apache.logging.log4j</groupId>
        <artifactId>log4j-api</artifactId>
        <version>2.11.2</version>
    </dependency>
    <dependency>
        <groupId>org.apache.logging.log4j</groupId>
        <artifactId>log4j-core</artifactId>
        <version>2.11.2</version>
    </dependency>

    <dependency>
        <groupId>javax.ejb</groupId>
        <artifactId>ejb-api</artifactId>
        <version>3.0</version>
        <scope>provided</scope>
    </dependency>
</dependencies>

Это мои бины. xml

<beans xmlns="http://xmlns.jcp.org/xml/ns/javaee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation=" http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/beans_1_1.xsd" bean-discovery-mode="annotated">
</beans>

Я использую Java 8.

РЕДАКТИРОВАТЬ: CacheManager создается в приложении JAX-WS

@ApplicationScoped
@ApplicationPath("/rest")
public class JaxRsActivator extends Application {

    private static final Logger logger = LogManager.getLogger();

    private Set<Object> singletons = new HashSet<Object>();
    private HashSet<Class<?>> classes = new HashSet<Class<?>>();

    public JaxRsActivator() {
        singletons.add(new CorsFilter());
        singletons.add(new CacheManager());      
    }   

    @Override
    public Set<Object> getSingletons() {
        return singletons;
    }

    @Override
    public HashSet<Class<?>> getClasses(){
      return classes;
    }
}

1 Ответ

0 голосов
/ 03 апреля 2020

Я нашел решения: @Singleton должен быть javax.ejb.Singleton, а не javax.inject.Singleton.

...