转载自:http://blog.csdn.net/ch717828/article/details/50818261

1. 开启Kafka Consumer

首先选择集群的一台机器,打开kafka consumer,接收发送给kafka的消息。我选择的是 10.101.214.71这台机器。

通过以下命令打开 Consumer 。还不了解的可以看  kafka集群环境搭建 http://blog.csdn.net/ch717828/article/details/50748872


  1. /usr/local/kafka_2.11-0.9.0.0/bin/kafka-console-consumer.sh --zookeeper 10.101.214.71:2181,10.101.214.73:2181,10.101.214.74:2181/kafka --from-beginning --topic TestTopic

2. Kafka配置文件修改

因为将要写的 Java代码在本地,而 kafka安装在集群的71,73,74这3台机器上。因此需要对kafka的配置文件做修改,下面以 71的配置为例,73,74的类似。

vim /usr/local/kafka/config/server.properties

主要修改的内容为下面两行


  1. host.name=10.101.214.71
  2. advertised.host.name=10.101.214.71​

3. Java实现Kafka Producer

使用maven 管理依赖包,pom.xml如下


  1. <dependency>
  2. <groupId>org.apache.kafka</groupId>
  3. <artifactId>kafka_2.11</artifactId>
  4. <version>0.8.2.1</version>
  5. </dependency>
  6. <dependency>
  7. <groupId>org.apache.kafka</groupId>
  8. <artifactId>kafka-clients</artifactId>
  9. <version>0.8.2.1</version>
  10. </dependency>

log4j.properties 配置如下


  1. log4j.rootLogger=INFO,console
  2. #for package com.demo.kafka, log would be sent to kafka appender.
  3. log4j.logger.com.demo.kafka=DEBUG,kafka
  4. ## appender kafka
  5. #log4j.appender.kafka=kafka.producer.KafkaLog4jAppender
  6. #log4j.appender.kafka.topic=my-replicated-topic5
  7. ## multiple brokers are separated by comma ",".
  8. #log4j.appender.kafka.brokerList=10.101.214.71:9092,10.101.214.73:9092,10.101.214.74:9092
  9. #log4j.appender.kafka.compressionType=none
  10. #log4j.appender.kafka.syncSend=true
  11. #log4j.appender.kafka.layout=org.apache.log4j.PatternLayout
  12. #log4j.appender.kafka.layout.ConversionPattern=%d [%-5p] [%t] - [%l] %m%n
  13. # appender console
  14. log4j.appender.console=org.apache.log4j.ConsoleAppender
  15. log4j.appender.console.target=System.out
  16. log4j.appender.console.layout=org.apache.log4j.PatternLayout
  17. log4j.appender.console.layout.ConversionPattern=%d [%-5p] [%t] - [%l] %m%n
 Java实现代码如下,只做Demo使用,因此没有 close掉

  1. import java.util.ArrayList;
  2. import java.util.List;
  3. import java.util.Properties;
  4. import kafka.javaapi.producer.Producer;
  5. import kafka.producer.KeyedMessage;
  6. import kafka.producer.ProducerConfig;
  7. public class MyProducer {
  8. private static final String TOPIC = "TestTopic"; //kafka创建的topic
  9. private static final String CONTENT = "This is a single message"; //要发送的内容
  10. private static final String BROKER_LIST = "10.101.214.71:9092,10.101.214.73:9092,10.101.214.74:9092"; //broker的地址和端口
  11. private static final String SERIALIZER_CLASS = "kafka.serializer.StringEncoder"; // 序列化类
  12. public static void main(String[] args) {
  13. Properties props = new Properties();
  14. props.put("serializer.class", SERIALIZER_CLASS);
  15. props.put("metadata.broker.list", BROKER_LIST);
  16. ProducerConfig config = new ProducerConfig(props);
  17. Producer<String, String> producer = new Producer<String, String>(config);
  18. //Send one message.
  19. KeyedMessage<String, String> message =
  20. new KeyedMessage<String, String>(TOPIC, CONTENT);
  21. producer.send(message);
  22. //Send multiple messages.
  23. List<KeyedMessage<String,String>> messages =
  24. new ArrayList<KeyedMessage<String, String>>();
  25. for (int i = 0; i < 5; i++) {
  26. messages.add(new KeyedMessage<String, String>
  27. (TOPIC, "Multiple message at a time. " + i));
  28. }
  29. producer.send(messages);
  30. }
  31. }
运行这段代码,同时观察 Kafka Consumer的输出。可以看到输出信息为


  1. This is a single message
  2. Multiple message at a time. 0
  3. Multiple message at a time. 1
  4. Multiple message at a time. 2
  5. Multiple message at a time. 3
  6. Multiple message at a time. 4

此时完成了 java来向kafka产生消息。

kafka_2.11-0.8.2.1生产者producer的Java实现的更多相关文章

  1. kafka_2.11-0.10.0.1生产者producer的Java实现

    转载自:http://blog.csdn.net/qq_26479655/article/details/52555283 首先导入包 将kafka目录下的libs中的jar包导入 用maven建立 ...

  2. kafka 0.8.2 消息生产者 producer

    package com.hashleaf.kafka; import java.util.Properties; import kafka.javaapi.producer.Producer; imp ...

  3. kafka 0.10.2 消息生产者(producer)

    package cn.xiaojf.kafka.producer; import org.apache.kafka.clients.producer.*; import org.apache.kafk ...

  4. Kafka 0.11.0.0 实现 producer的Exactly-once 语义(官方DEMO)

    <dependency> <groupId>org.apache.kafka</groupId> <artifactId>kafka-clients&l ...

  5. kafka 0.8.2 消息生产者 KafkaProducer

    package com.hashleaf.kafka; import java.util.Properties; import java.util.concurrent.ExecutorService ...

  6. kafka_2.11-2.0.0_安装部署

    参考博文:kafka 配置文件参数详解 参考博文:Kafka[第一篇]Kafka集群搭建 参考博文:如何为Kafka集群选择合适的Partitions数量 参考博文:Kafka Server.prop ...

  7. 【转】 详解Kafka生产者Producer配置

    粘贴一下这个配置,与我自己的程序做对比,看看能不能完善我的异步带代码:   -----------------------------------------    详解Kafka生产者Produce ...

  8. centos7安装kafka_2.11-1.0.0 新手入门

    系统环境 1.操作系统:64位CentOS Linux release 7.2.1511 (Core) 2.jdk版本:1.8.0_121 3.zookeeper版本:zookeeper-3.4.9. ...

  9. SQLLocalDB 11.0持续报错,这是泥马德什么问题啊!!!

    Windows API 调用 WaitForMultipleObjects 返回了错误代码: 575.Windows 系统错误消息为: {应用程序错误}应用程序无法正常启动(0x%lx).请单击“确定 ...

随机推荐

  1. python里的函数

    map()是 Python 内置的高阶函数,它接收一个函数 f 和一个 list,并通过把函数 f 依次作用在 list 的每个元素上,得到一个新的 list 并返回. 假设用户输入的英文名字不规范, ...

  2. Ubuntu上latex+atom配置

    网上流传的latex+atom大都是windows上的,Ubuntu与windows上的配置方式大同小异,这里写下自己的经验: 分为三个步骤,首先安装texlive,texlive是latex的依赖库 ...

  3. javascript的this多种场景用法

    作者:刘志祥 时间:2017.11.10 参考:阮一峰的官方网站 this 是javaScript中的一个关键字,只能在函数内使用.随着场合的不同,this的值会发生变化. 1. 单纯的全局函数调用, ...

  4. Unity 3D光源-Directional平行光/逆光效果,光晕详解、教程

    Unity4大光源之平行光 本文提供全流程,中文翻译. Chinar 坚持将简单的生活方式,带给世人!(拥有更好的阅读体验 -- 高分辨率用户请根据需求调整网页缩放比例) Chinar -- 心分享. ...

  5. select的width和input的width

    select的width包括了border,而input不包括

  6. 人工智能之KNN算法

    转载自:https://www.cnblogs.com/magic-girl/p/python-kNN.html 基于python实现的KNN算法 邻近算法(k-NearestNeighbor) 是机 ...

  7. Blender 曲线操作

    Curve (Bézier Versus NURBS)https://en.wikibooks.org/wiki/Blender_3D:_Noob_to_Pro/Curve_and_Path_Mode ...

  8. Python学习之---Python中的内置函数(方法)(更新中。。。)

    add(item)   #将item添加到s中,如果item已经在s中,则无任何效果 break        #退出循环,不会再运行循环中余下的代码 bool()     #将参数转换为布尔型 by ...

  9. C++学习(十七)(C语言部分)之 指针

    复习 数组定义格式 类型 数组名[数组大小]数组名+下标 int arr[2][3]={{1,2,3},{4,5,6}}; int arr[][3]={1,2,3,4,5,6};//二维数组定义的时候 ...

  10. WEBapi在IIS发布注意事项-发布错误

    发布报错:403.14-Forbidden Web 服务器被配置为不列出此目录的内容 解决方法: 1)打开IIS管理器 2)找到功能视图的目录浏览 3)双击进入后,点击右侧操作栏-启用