kafka是吞吐量巨大的一个消息系统,它是用scala写的,和普通的消息的生产消费还有所不同,写了个demo程序供大家参考。kafka的安装请参考官方文档。

首先我们需要新建一个maven项目,然后在pom中引用kafka jar包,引用依赖如下:


  1. <dependency>
  2. <groupId>org.apache.kafka</groupId>
  3. <artifactId>kafka_2.11</artifactId>
  4. <version>0.8.2.1</version>
  5. </dependency>

我们用的版本是0.8, 下面我们看下生产消息的代码:


  1. package com.telewave.kafka.util;
  2. import java.util.Properties;
  3. import kafka.javaapi.producer.Producer;
  4. import kafka.producer.KeyedMessage;
  5. import kafka.producer.ProducerConfig;
  6. /**
  7. *
  8. * Hello world!
  9. *
  10. *
  11. */
  12. public class KafkaProducer
  13. {
  14. private final Producer<String, String> producer;
  15. public final static String TOPIC = "TestTopic";
  16. private KafkaProducer() {
  17. Properties props = new Properties();
  18. // 此处配置的是kafka的端口
  19. props.put("metadata.broker.list", "192.168.168.200:9092");
  20. // 配置value的序列化类
  21. props.put("serializer.class", "kafka.serializer.StringEncoder");
  22. // 配置key的序列化类
  23. props.put("key.serializer.class", "kafka.serializer.StringEncoder");
  24. // request.required.acks
  25. // 0, which means that the producer never waits for an acknowledgement
  26. // from the broker (the same behavior as 0.7). This option provides the
  27. // lowest latency but the weakest durability guarantees (some data will
  28. // be lost when a server fails).
  29. // 1, which means that the producer gets an acknowledgement after the
  30. // leader replica has received the data. This option provides better
  31. // durability as the client waits until the server acknowledges the
  32. // request as successful (only messages that were written to the
  33. // now-dead leader but not yet replicated will be lost).
  34. // -1, which means that the producer gets an acknowledgement after all
  35. // in-sync replicas have received the data. This option provides the
  36. // best durability, we guarantee that no messages will be lost as long
  37. // as at least one in sync replica remains.
  38. props.put("request.required.acks", "-1");
  39. producer = new Producer<String, String>(new ProducerConfig(props));
  40. }
  41. void produce() {
  42. int messageNo = 1000;
  43. final int COUNT = 10000;
  44. while (messageNo < COUNT) {
  45. String key = String.valueOf(messageNo);
  46. String data = "hello kafka message " + key;
  47. producer.send(new KeyedMessage<String, String>(TOPIC, key, data));
  48. System.out.println(data);
  49. messageNo++;
  50. }
  51. }
  52. public static void main(String[] args)
  53. {
  54. new KafkaProducer().produce();
  55. }
  56. }

下面是消费端的代码实现:


  1. package com.telewave.kafka.util;
  2. import java.util.HashMap;
  3. import java.util.List;
  4. import java.util.Map;
  5. import java.util.Properties;
  6. import org.apache.kafka.clients.producer.KafkaProducer;
  7. import kafka.consumer.ConsumerConfig;
  8. import kafka.consumer.ConsumerIterator;
  9. import kafka.consumer.KafkaStream;
  10. import kafka.javaapi.consumer.ConsumerConnector;
  11. import kafka.serializer.StringDecoder;
  12. import kafka.utils.VerifiableProperties;
  13. public class KafkaConsumer {
  14. private final ConsumerConnector consumer;
  15. public KafkaConsumer() {
  16. Properties props = new Properties();
  17. // zookeeper 配置
  18. props.put("zookeeper.connect", "192.168.168.200:2181");
  19. // group 代表一个消费组
  20. props.put("group.id", "jd-group");
  21. // zk连接超时
  22. props.put("zookeeper.session.timeout.ms", "4000");
  23. props.put("zookeeper.sync.time.ms", "200");
  24. props.put("auto.commit.interval.ms", "1000");
  25. props.put("auto.offset.reset", "largest");
  26. // 序列化类
  27. props.put("serializer.class", "kafka.serializer.StringEncoder");
  28. ConsumerConfig config = new ConsumerConfig(props);
  29. consumer = kafka.consumer.Consumer.createJavaConsumerConnector(config);
  30. }
  31. public void consume() {
  32. Map<String, Integer> topicCountMap = new HashMap<String, Integer>();
  33. topicCountMap.put("TestTopic", new Integer(1));
  34. StringDecoder keyDecoder = new StringDecoder(new VerifiableProperties());
  35. StringDecoder valueDecoder = new StringDecoder(
  36. new VerifiableProperties());
  37. Map<String, List<KafkaStream<String, String>>> consumerMap =
  38. consumer.createMessageStreams(topicCountMap, keyDecoder, valueDecoder);
  39. KafkaStream<String, String> stream = consumerMap.get(
  40. "TestTopic").get(0);
  41. ConsumerIterator<String, String> it = stream.iterator();
  42. while (it.hasNext())
  43. System.out.println(it.next().message());
  44. }
  45. public static void main(String[] args) {
  46. new KafkaConsumer().consume();
  47. }
  48. }

kafka_2.11-0.8.2.1+java 生产消费程序demo示例的更多相关文章

  1. kafka之三:kafka java 生产消费程序demo示例

    kafka是吞吐量巨大的一个消息系统,它是用scala写的,和普通的消息的生产消费还有所不同,写了个demo程序供大家参考.kafka的安装请参考官方文档. 首先我们需要新建一个maven项目,然后在 ...

  2. 试驾 Citus 11.0 beta

    https://www.citusdata.com/blog/2022/03/26/test-drive-citus-11-beta-for-postgres/ Citus 11.0 beta 的最大 ...

  3. java10.0.2和java 11.0.1配置环境变量

    java10.0.2 在网上找了各种方法一直也没配好打开jak下的lib文件夹发现并没有tools.jar,后经查询jdk-9后就没有了上述.jar文件所以我的配置方法如下 ClASSPATH C:\ ...

  4. java编程如何实现多条2017-01-16 22:28:11.0这样的时间数据,转换成Date类型Mon Jan 16 22:28:11 CST 2017这样的时间数据

    不多说,直接上干货! package zhouls.bigdata.DataFeatureSelection.sim; import java.text.ParseException; import ...

  5. JDBC中 mysql数据库的连接工具类 Java登录 及增删改查 整理 附带:Navicat Premium 11.0.12中文破解版.zip(下载)mysql数据库工具

    先写一个工具类,有实现MySQL数据库连接的方法,和关闭数据库连接.关闭ResultSet  结果集.关闭PreparedStatement 的方法.代码如下: package com.swift; ...

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

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

  7. CM5(5.11.0)和CDH5(5.11.0)离线安装

    概述 文件下载 系统环境搭建 日志查看 Q&A 参考 概述 CDH (Cloudera's Distribution, including Apache Hadoop),是Hadoop众多分支 ...

  8. Kafka生产消费API JAVA实现

    Maven依赖: <dependency> <groupId>org.apache.kafka</groupId> <artifactId>kafka- ...

  9. RemotelyAnywhere 11.0.2716 SERVER EDITION 绿色破解安装版

    RemotelyAnywhere是一个小巧的,利用浏览器进行远程控制的小程序.只要在服务器端安装该软件,然后你就可以通过任何一个支持 Java 的浏览器对远程计算机进行控制了.通过它,你可以管理远程计 ...

随机推荐

  1. 本周java 学习进度报告

    本周java 学习进度报告 本周对我的感触很深,因为这是我初学java 语言的第一周,我认识到java 和c语言是有很多的不同之处和相同之处.我这几天几乎是在研究java 基础入门知识,而并没有太多的 ...

  2. React Native项目集成iOS原生模块

    今天学习一下怎么在React Native项目中集成iOS原生模块,道理和在iOS原生项目中集成React Native模块类似.他们的界面跳转靠的都是iOS原生的UINavigationContro ...

  3. 找出n个自然数(1,2,3,……,n)中取r个数的组合

    <?php /** * 对于$n和$r比较小, 可以用这种方法(当n=5, r=3时) */ function permutation1($n, $r) { for($i=1; $i<=$ ...

  4. php经典算法实现(转)

    <?  //--------------------  // 基本数据结构算法 //--------------------  //二分查找(数组里查找某个元素)  function bin_s ...

  5. 【leetcode】344. Reverse String

    problem 344. Reverse String solution: class Solution { public: void reverseString(vector<char> ...

  6. 设计简单算法体验Vivado HLS的使用

    前言 本文主要讲解了使用Vivado HLS设计简单C语言的二选一选择器算法的硬件HLS开发的全流程,包括工程创建-算法验证和仿真-算法综合-RTL仿真-IP封装等步骤. 参考网站: http://b ...

  7. [LeetCode&Python] Problem 350. Intersection of Two Arrays II

    Given two arrays, write a function to compute their intersection. Example 1: Input: nums1 = [1,2,2,1 ...

  8. C#LinQ语法

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

  9. HDU - 5157 :Harry and magic string (回文树,求多少对不相交的回文串)

    Sample Input aca aaaa Sample Output 3 15 题意: 多组输入,每次给定字符串S(|S|<1e5),求多少对不相交的回文串. 思路:可以用回文树求出以每个位置 ...

  10. 对Functional Language的认识

    What: A functional language is a programming language built over and around logical functions or pro ...