linux本地连接kafka生产者和消费者可以成功但是通过javaAPI操作生产者发送消息不成功报错org.apache.kafka.common.errors.TimeoutException

通过命令行工具连接服务器本地操作(kafka-console-producer.sh和kafka-console-consumer.sh)是能够相互通信的,producer发布的信息consumer能够接收到。

但是
java通过kafka-client的API写的代码始终不能跟kafka通信:java producer的消息发不出去, java comsumer也收不到任何消息。
仔细检查了下代码中IP、端口都没有写错。
服务器的防火墙也是关闭的。

解决办法

将kafka/config/server.properties文件中advertised.listeners改为如下属性。
192.168.32.XXX是我虚拟机的IP。

advertised.listeners=PLAINTEXT://192.168.32.XXX:9092

修改后消费者的命令监控的ip也要从loacalhost改为192.168.32.XXX

 kafka-console-consumer.sh --bootstrap-server 192.168.32.XXX:9092 --topic topic_1 --from-beginning

不然也无法接收到消息`在

      {
        Map<String,Object> configs = new HashMap<>();
//        设置连接Kafka的初始连接⽤到的服务器地址
        configs.put("bootstrap.servers","192.168.32.129:9092");
//        设置key的序列化器
        configs.put("key.serializer", IntegerSerializer.class);
//        设置value的序列化器
        configs.put("value.serializer", StringSerializer.class);
        
//        configs.put("acks","all");
//        
//        configs.put("reties","3");


        KafkaProducer<Integer,String> producer=new KafkaProducer<Integer, String>(configs);

        List<Header> headers = new ArrayList<>();
        headers.add(new RecordHeader("biz.name","producer.demo".getBytes()));

        ProducerRecord<Integer, String> record = new ProducerRecord<Integer, String>(
                "topic_1", // 主题名称
                0,  // 分区编号,现在只有⼀个分区,所以是0
                0,  // 数字作为key
                "message 0",  // 字符串作为value
                headers
        );

        //消息同步确认
        final Future<RecordMetadata> future = producer.send(record);
        final RecordMetadata metadata = future.get();
        System.out.println("主题"+ metadata.topic());
        System.out.println("分区" + metadata.partition());
        System.out.println("偏移量" + metadata.offset());

        //关闭生产者
        producer.close();

    }

成功后

idea返回
idea返回结果

消费者接受发了两次message 0
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值