IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 大数据 -> linux本地连接kafka生产者和消费者可以成功但是通过javaAPI操作生产者发送消息不成功报错org.apache.kafka.common.errors.TimeoutException -> 正文阅读

[大数据]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
在这里插入图片描述

  大数据 最新文章
实现Kafka至少消费一次
亚马逊云科技:还在苦于ETL?Zero ETL的时代
初探MapReduce
【SpringBoot框架篇】32.基于注解+redis实现
Elasticsearch:如何减少 Elasticsearch 集
Go redis操作
Redis面试题
专题五 Redis高并发场景
基于GBase8s和Calcite的多数据源查询
Redis——底层数据结构原理
上一篇文章      下一篇文章      查看所有文章
加:2021-11-10 12:28:04  更:2021-11-10 12:30:05 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/18 0:30:24-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码