springboot整合kafka的基本使用

该博客介绍了如何在SpringBoot应用中整合Kafka,包括配置YML文件、设置账户认证、创建Kafka配置类、生产者组件及消费者监听。内容详细涵盖了依赖引入、配置参数、发送和接收消息的方法,以及错误处理。注意同一groupId的消费者中只有一个能接收消息。
摘要由CSDN通过智能技术生成

springboot整合kafka的基本使用

导入依赖包

    	<dependency>
            <groupId>org.springframework.kafka</groupId>
            <artifactId>spring-kafka</artifactId>
        </dependency>

yml配置

spring:
  kafka:
    producer:
      bootstrap-servers: ip:9092 #ip端口号
      retries: 1
      linger-ms: 1
      batch-size: 16384
      buffer-memory: 33554432
      key-serializer: org.apache.kafka.common.serialization.StringSerializer
      value-serializer: org.apache.kafka.common.serialization.StringSerializer
    consumer:
      bootstrap-servers: ip:9092 #ip端口号
      auto-offset-reset: latest
      enable-auto-commit: true
      auto-commit-interval: 1000
      key-deserializer: org.apache.kafka.common.serialization.StringDeserializer
      value-deserializer: org.apache.kafka.common.serialization.StringDeserializer
      

账户认证

如果需要账户认证可在项目路径下创建kafka_client_jaas.conf文件,并设置账号密码,文件内容:

KafkaClient {
org.apache.kafka.common.security.plain.PlainLoginModule required
username="root"  
password="123456";
};

kafka配置类

@Configuration
@EnableKafka
public class KafkaConfiguration {

    @Value("${spring.kafka.bootstrap-servers}")
    private String servers;
    @Value("${spring.kafka.producer.retries}")
    private int retries;
    @Value("${spring.kafka.producer.batch-size}")
    private int batchSize;
    @Value("${spring.kafka.producer.linger-ms}")
    private int linger;
    @Value("${spring.kafka.producer.buffer-memory}")
    private int bufferMemory;


//注释部分为需要账户认证代码
    public Map<String, Object> producerConfigs() {
//        System.setProperty("java.security.auth.login.config", "kafka_client_jaas.conf"); //配置文件路径
        Map<String, Object> props = new HashMap<>();
        props.put(ProducerConfig.BOOTSTRAP_SERVERS_CONFIG, servers);
        props.put(ProducerConfig.RETRIES_CONFIG, retries);
        props.put(ProducerConfig.BATCH_SIZE_CONFIG, batchSize);
        props.put(ProducerConfig.LINGER_MS_CONFIG, linger);
        props.put(ProducerConfig.BUFFER_MEMORY_CONFIG, bufferMemory);
        props.put(ProducerConfig.KEY_SERIALIZER_CLASS_CONFIG, StringSerializer.class);
        props.put(ProducerConfig.VALUE_SERIALIZER_CLASS_CONFIG, StringSerializer.class);
//        props.put("security.protocol", "SASL_PLAINTEXT");
//        props.put("sasl.mechanism", "PLAIN");
        return props;
    }

    public ProducerFactory<String, String> producerFactory() {
        return new DefaultKafkaProducerFactory<>(producerConfigs());
    }

    @Bean
    public KafkaTemplate<String, String> kafkaTemplate() {
        return new KafkaTemplate<String, String>(producerFactory());
    }
}

kafka生产者

@Component
@Slf4j
public class KafkaProducer1 {
    @Autowired
    private KafkaTemplate<String, String> kafkaTemplate;

    public void sendMessage(String topic,String key,String jsonData) {
        try {
            kafkaTemplate.send(topic, key, jsonData);
        }catch (Exception e) {
            log.error("发送数据出错!!!{}{}", topic, jsonData);
            log.error("发送数据出错",e);
        }

        kafkaTemplate.setProducerListener(new ProducerListener() {
            @Override
            public void onSuccess(ProducerRecord producerRecord, RecordMetadata recordMetadata) {
                log.info("向kafka推送数据成功:[{}]", topic);
            }

            @Override
            public void onError(ProducerRecord producerRecord, RecordMetadata recordMetadata, Exception exception) {
                log.error("向kafka推送数据失败:{}{}",topic,key);
            }

        });

    }
}

消费者监听kafka

@Service
@Slf4j
public class CarTrackServiceImpl implements CarTrackService {
    @KafkaListener(topics = {"test"},groupId = "com-test")
    public void listen3(ConsumerRecord<?, ?> record){
        System.out.println(record);
        Optional<? extends ConsumerRecord<?, ?>> record1 = Optional.ofNullable(record);
        if (record1.isPresent()) {
            log.info("接收端:{}",record1);
        }

    }
}

注意当多个消费者都为同一个groupId时则只有一个消费者能接收到消息。

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值