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