kafka入门

1.环境配置

kafka依赖zookeeper来调度,以及选举leader,因此需要先安装zookeeper

1.1 安装zookeeper

点击下载zookeeper下载合适版本的zookeeper,当前最新的稳定版本是3.4.9创建好数据目录,命名为data,下一步配置用到

$ cd opt/ && tar -zxf zookeeper-3.4.6.tar.gz  && cd zookeeper-3.4.6
$ mkdir data

1.2 配置zookeeper

$ vi conf/zoo.cfg
tickTime=2000
dataDir=/path/to/zookeeper/data
clientPort=2181
initLimit=5
syncLimit=2

1.3 启动zookeeper

$ bin/zkServer.sh start

相应的停止zookeeper的命令为:

 $ bin/zkServer.sh stop

1.4 启动zookeeper CLI

$ bin/zkCli.sh

1.2 安装kafka

1.2.1 下载并解压

点击下载kafka的压缩包

$ cd opt/
$ tar -zxf kafka_2.11-0.10.1.0.tgz
$ cd kafka_2.11-0.10.1.0

1.3.1 启动和关闭Kafka

启动kafka

$ bin/kafka-server-start.sh config/server.properties

关闭kafka

$ bin/kafka-server-stop.sh config/server.properties

2.测试单broker

我的kafka服务创建在Linux虚拟机上,IP地址为:192.168.61.131(按需替换成自己的IP地址),在这里需要配置server.properties文件,将advertised.host.name设置为虚拟机的IP地址 advertised.host.name=192.168.61.131,否则在宿主机上无法访问虚拟机上面的服务

2.1 使用Shell命令测试topic

2.1.1 创建topic

在命令行界面kafka目录,输入下面命令:

bin/kafka-topics.sh --create --zookeeper localhost:2181 --replication-factor 1 --partitions 1 --topic page_visits

2.1.2 测试发布者

输入以下命令,打开发布消息CLI

bin/kafka-console-producer.sh --broker-list localhost:9092 --topic page_visits

在CLI界面输入,两行测试消息

Hello kafka
你好吗?

2.1.3 测试订阅者

输入一下命令打开订阅者CLI

bin/kafka-console-consumer.sh --bootstrap-server localhost:9092 --zookeeper localhost:2181 --from-beginning --topic page_visits

如果执行正确,会显示刚才发布者发送的两行消息

2.2 使用Java代码创建Client来发布订阅消息

需要先在pom中添加kafka依赖:

     <dependencies>
             <dependency>
                 <groupId>org.apache.kafka</groupId>
                 <artifactId>kafka_2.9.2</artifactId>
                 <version>0.8.1.1</version>
                 <scope>compile</scope>
                 <exclusions>
                     <exclusion>
                         <artifactId>jmxri</artifactId>
                         <groupId>com.sun.jmx</groupId>
                     </exclusion>
                     <exclusion>
                         <artifactId>jms</artifactId>
                         <groupId>javax.jms</groupId>
                     </exclusion>
                     <exclusion>
                         <artifactId>jmxtools</artifactId>
                         <groupId>com.sun.jdmk</groupId>
                     </exclusion>
                 </exclusions>
             </dependency>
             <dependency>
                 <groupId>org.apache.kafka</groupId>
                 <artifactId>kafka-clients</artifactId>
                 <version>0.9.0.0</version>
             </dependency>
     
         </dependencies>

2.2.1 创建发布者发布消息

下面一段代码,会每隔3秒中发布一个测试消息

  public class MyProducer {
      private final static String TOPIC = "page_visits";
  
      public static void main(String[] args) throws InterruptedException {
          long events = 100;
          Properties properties = new Properties();
          properties.put("metadata.broker.list", "192.168.61.131:9092");
          properties.put("serializer.class", "kafka.serializer.StringEncoder");
  
          ProducerConfig config = new ProducerConfig(properties);
          Producer<String, String> producer = new Producer<String, String>(config);
          for (long nEvent = 0; nEvent< events; nEvent++){
              SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
              KeyedMessage<String,String> data = new KeyedMessage<String, String>(TOPIC,String.valueOf(nEvent),"Test message from java program " + sdf.format(new Date()));
              Thread.sleep(3000);
              producer.send(data);
          }
          producer.close();
  
  
      }
  }

2.2.2 创建订阅者订阅消息

下面的代码会绑定到虚拟机长的kafka服务,当发布者发布消息时,订阅者会不断地打印发布者发布的消息:

public class MyConsumer {
    private final static String TOPIC = "page_visits";

    public static void main(String[] args) {
        Properties properties = new Properties();
        properties.put("bootstrap.servers","192.168.61.131:9092");
        properties.put("enable.auto.commit", "true");
        properties.put("group.id", "test");
        properties.put("auto.commit.interval.ms", "1000");
        properties.put("session.timeout.ms", "30000");
        properties.put("key.deserializer", "org.apache.kafka.common.serialization.StringDeserializer");
        properties.put("value.deserializer","org.apache.kafka.common.serialization.StringDeserializer");

        KafkaConsumer<String,String> consumer = new KafkaConsumer<String, String>(properties);
        consumer.subscribe(Arrays.asList(TOPIC));
        System.out.println("Subscribe to topic "+TOPIC);
        while (true){
            ConsumerRecords<String,String> consumerRecords = consumer.poll(100);
            for(ConsumerRecord<String,String> record: consumerRecords){
                System.out.printf("offset = %d,key = %s,value = %s\n",record.offset(),record.key(),record.value());
            }
        }

    }
}
运行结果
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 205,132评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,802评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,566评论 0 338
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,858评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,867评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,695评论 1 282
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,064评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,705评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 42,915评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,677评论 2 323
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,796评论 1 333
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,432评论 4 322
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,041评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,992评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,223评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,185评论 2 352
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,535评论 2 343

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,598评论 18 139
  • Kafka入门经典教程-Kafka-about云开发 http://www.aboutyun.com/threa...
    葡萄喃喃呓语阅读 10,805评论 4 54
  • Kafka官网:http://kafka.apache.org/入门1.1 介绍Kafka™ 是一个分布式流处理系...
    it_zzy阅读 3,877评论 3 53
  • 一、基本概念 介绍 Kafka是一个分布式的、可分区的、可复制的消息系统。它提供了普通消息系统的功能,但具有自己独...
    ITsupuerlady阅读 1,618评论 0 9
  • 在 Android开发之那些好用的数据结构与API 一文中提到了Android中一些好用的数据结构和API,这次继...
    YungFan阅读 3,864评论 24 97