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

tech.mhuang.pacebox.kafka.admin.KafkaFramework Maven / Gradle / Ivy

package tech.mhuang.pacebox.kafka.admin;

import lombok.Getter;
import lombok.Setter;
import lombok.extern.slf4j.Slf4j;
import tech.mhuang.pacebox.core.check.CheckAssert;
import tech.mhuang.pacebox.core.dict.BasicDict;
import tech.mhuang.pacebox.core.pool.BaseExecutor;
import tech.mhuang.pacebox.core.pool.DefaultThreadPool;
import tech.mhuang.pacebox.core.util.CollectionUtil;
import tech.mhuang.pacebox.core.util.StringUtil;
import tech.mhuang.pacebox.json.BaseJsonService;
import tech.mhuang.pacebox.json.jackson.JacksonJsonService;
import tech.mhuang.pacebox.kafka.admin.bean.KafkaInfo;
import tech.mhuang.pacebox.kafka.admin.external.IKafkaConsumer;
import tech.mhuang.pacebox.kafka.admin.external.IKafkaExternal;
import tech.mhuang.pacebox.kafka.admin.external.IKafkaProducer;
import tech.mhuang.pacebox.kafka.consumer.bean.ConsumerBean;
import tech.mhuang.pacebox.kafka.consumer.generator.KafkaConsumerGenerator;
import tech.mhuang.pacebox.kafka.global.exception.JkafkaException;
import tech.mhuang.pacebox.kafka.producer.bean.ProducerBean;

import java.util.List;
import java.util.Map;
import java.util.concurrent.ConcurrentHashMap;

/**
 * kafka的信息
 *
 * @author mhuang
 * @since 1.0.0
 */
@Slf4j
public class KafkaFramework {

    /**
     * kafka全部配置
     */
    @Getter
    private final KafkaInfo info;

    /**
     * 启动成功的kafka生产者(可用于获取变更等进行处理)
     */
    @Getter
    private final Map successProducerMap = new ConcurrentHashMap<>();

    /**
     * 启动成功的kafka消费者(可用于获取变更等进行处理)
     */
    @Getter
    private final Map successConsumerMap = new ConcurrentHashMap<>();

    /**
     * 线程池(消费者使用)
     */
    @Getter
    private BaseExecutor executorService;

    /**
     * 提供kafka生产、消费bean扩展(可自定义生产、消费处理等方式)
     */
    @Getter
    private IKafkaExternal kafkaExternal;

    @Setter
    private BaseJsonService jsonConverter = new JacksonJsonService();


    public KafkaFramework(KafkaInfo info) {
        this.info = info;
    }

    /**
     * 自己构建的线程池
     *
     * @param executorService 线程池
     * @return 返回kafka框架
     */
    public KafkaFramework executorService(BaseExecutor executorService) {
        this.executorService = executorService;
        return this;
    }

    /**
     * 自行创建时将继承的扩展接口
     *
     * @param kafkaExternal 扩展接口
     * @return 返回kafka框架
     */
    public KafkaFramework kafkaExternal(IKafkaExternal kafkaExternal) {
        this.kafkaExternal = kafkaExternal;
        return this;
    }

    /**
     * 启动
     */
    public void start() {
        log.info("loading kafka client....");
        if (kafkaExternal == null) {
            kafkaExternal = new IKafkaExternal() {
            };
        }
        if (executorService == null) {
            executorService = new DefaultThreadPool();
        }
        //生产者启动
        if (info.isEnableProducer()) {
            if (CollectionUtil.isEmpty(info.getProducerMap())) {
                throw new JkafkaException("生产者启动但没有配置对应生产者,...");
            }
            info.getProducerMap().forEach((key, value) -> {
                if (value.isEnable()) {
                    generatorPro(key, value);
                }
            });
        }
        //消费者启动
        if (info.isEnableConsumer()) {
            if (CollectionUtil.isEmpty(info.getConsumerMap())) {
                throw new JkafkaException("消费者启动但没有配置对应消费者,...");
            }
            info.getConsumerMap().forEach((key, value) -> {
                if (value.isEnable()) {
                    generatorCon(key, value);
                }
            });
        }
        log.info("start kafka client success..");
    }

    /**
     * 构建生产者
     *
     * @param key 建
     * @param value 值
     */
    private void generatorPro(String key, ProducerBean value) {
        if (StringUtil.isEmpty(value.getServers())) {
            CheckAssert.check(info.getServers(), String.format("生产者%s:没有绑定对应的属性", key));
            value.setServers(info.getServers());
        }

        IKafkaProducer kafkaProducer = kafkaExternal.createProducer(key);
        kafkaProducer.execute(jsonConverter.toDict(value));
        successProducerMap.put(key, kafkaProducer);
    }

    /**
     * 构建消费者
     *
     * @param key 建
     * @param value 值
     */
    private void generatorCon(String key, ConsumerBean value) {
        if (StringUtil.isEmpty(value.getServers())) {
            CheckAssert.check(info.getServers(), String.format("消费者%s:没有绑定对应实例", key));
            value.setServers(info.getServers());
        }
        CheckAssert.check(value.getTopics(), String.format("消费者%s:没有指定对应主题", key));
        CheckAssert.check(value.getInvokeBeanName(), String.format("消费者%s:没有指定对应的调用bean", key));
        CheckAssert.check(value.getInvokeMethodName(), String.format("消费者%s:没有指定对应的方法名", key));
        List partionParamList = KafkaConsumerGenerator.generatorParam(value,jsonConverter);
        if (CollectionUtil.isNotEmpty(partionParamList)) {
            partionParamList.forEach(partition -> {
                String createKey = partition.get("consumerMap",Map.class).get("group.id").toString();
                IKafkaConsumer kafkaConsumer = kafkaExternal.createConsumer(createKey);
                kafkaConsumer.execute(partition);
                executorService.submit(kafkaConsumer);
                successConsumerMap.put(createKey, kafkaConsumer);
            });
        }
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy