@Configuration配置
import org.apache.kafka.clients.producer.ProducerConfig;
import org.apache.kafka.clients.producer.RoundRobinPartitioner;
import org.apache.kafka.common.serialization.StringSerializer;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.kafka.core.DefaultKafkaProducerFactory;
import org.springframework.kafka.core.KafkaTemplate;
import java.util.HashMap;
@Configuration
public class KafkaTemplateConfig {
@Value("${spring.kafka.servers}")
private String bootstrap_servers_config;
@Value("${spring.kafka.producer.retries}")
private String retries_config;
@Value("${spring.kafka.producer.batch-size}")
private String batch_size_config;
@Value("${spring.kafka.producer.buffer-memory}")
private String buffer_memory_config;
@Bean(name = "myKafkaTemplate")
public KafkaTemplate kafkaTemplate() {
HashMap<String, Object> configs = new HashMap<>();
configs.put(ProducerConfig.BOOTSTRAP_SERVERS_CONFIG, bootstrap_servers_config);
configs.put(ProducerConfig.RETRIES_CONFIG, retries_config);
configs.put(ProducerConfig.BATCH_SIZE_CONFIG, batch_size_config);
configs.put(ProducerConfig.BUFFER_MEMORY_CONFIG, buffer_memory_config);
configs.put(ProducerConfig.KEY_SERIALIZER_CLASS_CONFIG, StringSerializer.class);
configs.put(ProducerConfig.VALUE_SERIALIZER_CLASS_CONFIG, StringSerializer.class);
configs.put(ProducerConfig.PARTITIONER_CLASS_CONFIG, RoundRobinPartitioner.class);
DefaultKafkaProducerFactory producerFactory = new DefaultKafkaProducerFactory(configs);
return new KafkaTemplate(producerFactory);
}
}
发送消息工具类
import com.webray.information.notice.api.enums.EventStatusEnum;
import com.webray.information.notice.api.vo.EventStatusVo;
import com.webray.information.notice.provider.util.JsonUtil;
import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.kafka.core.KafkaTemplate;
import org.springframework.kafka.support.SendResult;
import org.springframework.stereotype.Component;
import org.springframework.util.concurrent.ListenableFuture;
import javax.annotation.Resource;
import java.time.LocalDateTime;
import java.time.ZoneOffset;
@Component
@Slf4j
public class EventKafkaProducer {
@Resource(name = "myKafkaTemplate")
private KafkaTemplate myKafkaTemplate;
@Value("${spring.kafka.producer.topic}")
private String topic;
public void sendMsg(String message) {
log.info("*************kafka发送消息**********************");
log.info("message:"+message);
if(null == message){
log.error("message不能为空");
return;
}
ListenableFuture<SendResult<String, String>> future = myKafkaTemplate.send(topic, message);
future.addCallback(success -> log.info("KafkaMessageProducer 发送消息成功!"),
fail -> log.error("KafkaMessageProducer 发送消息失败!"));
}
public void sendMsg(Object vo) {
sendMsg(JsonUtil.toJson(vo));
}
}
发送消息
注入EventKafkaProducer
@Autowired
private EventKafkaProducer eventKafkaProducer;
发送消息
eventKafkaProducer.sendMsg("我是傻逼");