All Downloads are FREE. Search and download functionalities are using the official Maven repository.

hu.icellmobilsoft.coffee.module.redisstream.bootstrap.BaseRedisConsumerStarter Maven / Gradle / Ivy

There is a newer version: 2.8.0
Show newest version
/*-
 * #%L
 * Coffee
 * %%
 * Copyright (C) 2020 i-Cell Mobilsoft Zrt.
 * %%
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 * 
 *      http://www.apache.org/licenses/LICENSE-2.0
 * 
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 * #L%
 */
package hu.icellmobilsoft.coffee.module.redisstream.bootstrap;

import java.util.Set;

import javax.annotation.Resource;
import javax.enterprise.concurrent.ManagedExecutorService;
import javax.enterprise.inject.Instance;
import javax.enterprise.inject.spi.Bean;
import javax.enterprise.inject.spi.BeanManager;
import javax.enterprise.inject.spi.CDI;
import javax.inject.Inject;

import hu.icellmobilsoft.coffee.module.redisstream.annotation.RedisStreamConsumer;
import hu.icellmobilsoft.coffee.module.redisstream.config.StreamGroupConfig;
import hu.icellmobilsoft.coffee.module.redisstream.consumer.IRedisStreamBaseConsumer;
import hu.icellmobilsoft.coffee.module.redisstream.consumer.IRedisStreamConsumerExecutor;
import hu.icellmobilsoft.coffee.module.redisstream.consumer.RedisStreamConsumerExecutor;
import hu.icellmobilsoft.coffee.se.logging.Logger;
import hu.icellmobilsoft.coffee.tool.utils.annotation.AnnotationUtil;

/**
 * Base Redis consumer starter algorithm. Must be activated on implemented project. This logic can be started with
 * 
    *
  • CDI: * *
     * import javax.enterprise.context.ApplicationScoped;
     * import javax.enterprise.context.Initialized;
     * import javax.enterprise.event.Observes;
     * 
     * @ApplicationScoped
     * public class ConsumerStarterCdi extends BaseRedisConsumerStarter {
     * 
     *     public void begin(@Observes @Initialized(ApplicationScoped.class) Object init) {
     *         start();
     *     }
     * }
     * 
    * *
  • *
  • EJB: * *
     * import javax.annotation.PostConstruct;
     * import javax.ejb.Singleton;
     * import javax.ejb.Startup;
     * 
     * @Startup
     * @Singleton
     * public class ConsumerStarterEjb extends BaseRedisConsumerStarter {
     * 
     *     @PostConstruct
     *     public void init() {
     *         start();
     *     }
     * }
     * 
    * *
  • *
  • CDI Extension need little changes because cant use Inject annotations and JNDI handling is limited
  • *
  • ... or other way
  • * *
* * @author imre.scheffer * @since 1.3.0 */ public class BaseRedisConsumerStarter { @Inject private Logger log; @Resource private ManagedExecutorService managedExecutorService; @Inject private StreamGroupConfig config; @Inject private BeanManager beanManager; /** * Start Redis consumers in separate long running managed threads */ public void start() { // kiszedjuk az osszes olyan osztalyt, ami a IRedisStreamConsumer interfeszt implementalja Set> beans = beanManager.getBeans(IRedisStreamBaseConsumer.class, RedisStreamConsumer.LITERAL); beans.stream().forEach(this::handleConsumerBean); } protected void handleConsumerBean(Bean bean) { log.info("Found consumer: [{0}]", bean.getBeanClass()); RedisStreamConsumer redisStreamConsumerAnnotation = AnnotationUtil.getAnnotation(bean.getBeanClass(), RedisStreamConsumer.class); // a coffee.redisstream beallitasok kellenek, annal a group a kulcs config.setConfigKey(redisStreamConsumerAnnotation.group()); int threads = config.getConsumerThreadsCount().orElse(redisStreamConsumerAnnotation.consumerThreadsCount()); // Letrehozunk annyi onnalo instance-t (dependent) amennyi a konfigban van megadva Instance consumerExecutor = CDI.current().select(RedisStreamConsumerExecutor.class); for (int i = 0; i < threads; i++) { IRedisStreamConsumerExecutor executor = consumerExecutor.get(); // kulon onnalo szalban inditjuk a vegtelen hallgatozo ciklust startThread(executor, redisStreamConsumerAnnotation, bean); } } @SuppressWarnings("unchecked") protected void startThread(IRedisStreamConsumerExecutor executor, RedisStreamConsumer redisStreamConsumerAnnotation, Bean bean) { executor.init(redisStreamConsumerAnnotation.configKey(), redisStreamConsumerAnnotation.group(), (Bean) bean); log.info("Starting Redis stream consumer with executor, class [{0}] for configKey [{1}], group [{2}]...", bean.getBeanClass(), redisStreamConsumerAnnotation.configKey(), redisStreamConsumerAnnotation.group()); managedExecutorService.submit(executor); log.info("consumer class [{0}] started.", bean.getBeanClass()); } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy