`
357029540
  • 浏览: 734875 次
  • 性别: Icon_minigender_1
  • 来自: 重庆
社区版块
存档分类
最新评论

kafka的Windows搭建及单机测试

阅读更多

         为了便于以后记忆,在这里把kafka在Windows的搭建方法和单机测试代码复制到了自己的博客里,分别参考的文章路径为http://www.cnblogs.com/alvingofast/p/kafka_deployment_on_windows.htmlhttp://chengjianxiaoxue.iteye.com/blog/2190488。以下是部分的复制内容。

搭建环境

1. 安装JDK

1.1 安装文件:http://www.oracle.com/technetwork/java/javase/downloads/jre8-downloads-2133155.html下载Server JRE.
1.2 安装完成后需要添加以下的环境变量(右键点击“我的电脑” -> "高级系统设置" -> "环境变量" ):

    • JAVA_HOME: C:\Program Files (x86)\Java\jre1.8.0_60(这个是默认安装路径,如果安装过程中更改了安装目录,把更改后的路径填上就行了)
    • PATH: 在现有的值后面添加"; %JAVA_HOME%\bin"

1.3 打开cmd运行 "java -version" 查看当前系统Java的版本:java-version

2. 安装Zookeeper

      Kafka的运行依赖于Zookeeper,所以在运行Kafka之前我们需要安装并运行Zookeeper

2.1 下载安装文件: http://zookeeper.apache.org/releases.html

2.2 解压文件(本文解压到 G:\zookeeper-3.4.8)

2.3 打开G:\zookeeper-3.4.8\conf,把zoo_sample.cfg重命名成zoo.cfg

2.4 从文本编辑器里打开zoo.cfg

2.5 把dataDir的值改成“:\zookeeper-3.4.8\data”

2.6 添加如下系统变量:

    1)ZOOKEEPER_HOME: G:\zookeeper-3.4.8

    2)Path: 在现有的值后面添加 ";%ZOOKEEPER_HOME%\bin;"

2.7 运行Zookeeper: 打开cmd然后执行zkserver

3. 安装并运行Kafka

      3.1 下载安装文件: http://kafka.apache.org/downloads.html

      3.2 解压文件(本文解压到 G:\kafka_2.11-0.10.0.1)

      3.3 打开G:\kafka_2.11-0.10.0.1\config

      3.4 从文本编辑器里打开 server.properties

      3.5 把 log.dirs的值改成 “G:\kafka_2.11-0.10.0.1\kafka-logs”

      3.6 打开cmd

      3.7 进入kafka文件目录: cd /d G:\kafka_2.11-0.10.0.1\

      3.8 输入并执行以打开kafka:

       .\bin\windows\kafka-server-start.bat .\config\server.properties

4. 创建topics

       4.1 打开cmd 并进入G:\kafka_2.11-0.10.0.1\bin\windows

      4.2 创建一个topic:

        kafka-topics.bat --create --zookeeper localhost:2181 --replication-factor 1 --partitions 1 --topic test 

5.打开一个Producer:

   cd /d G:\kafka_2.11-0.10.0.1\bin\windows kafka-console-producer.bat --broker-list localhost:9092 --topic test

6. 打开一个Consumer:

   cd /d G:\kafka_2.11-0.10.0.1\bin\windows

     kafka-console-consumer.bat --zookeeper localhost:2181 --topic test

     然后就可以在Producer控制台窗口输入消息了。在消息输入过后,很快Consumer窗口就会显示出Producer发送的消息:

至此,Kafka运行环境的搭建就完成了。

本地测试代码

1.java端生产数据, kafka集群消费数据:

1 创建maven工程,pom.xml中增加如下:  
 <dependency>  
        <groupId>org.apache.kafka</groupId>  
        <artifactId>kafka_2.10</artifactId>  
        <version>0.8.2.0</version>  
    </dependency>  
  
  
2 java代码:  向主题test内写入数据  
  
import java.util.Properties;  
import java.util.concurrent.TimeUnit;  
  
import kafka.javaapi.producer.Producer;  
import kafka.producer.KeyedMessage;  
import kafka.producer.ProducerConfig;  
import kafka.serializer.StringEncoder;  
  
  
  
  
public class kafkaProducer extends Thread{  
  
    private String topic;  
      
    public kafkaProducer(String topic){  
        super();  
        this.topic = topic;  
    }  
      
      
    @Override  
    public void run() {  
        Producer producer = createProducer();  
        int i=0;  
        while(true){  
            producer.send(new KeyedMessage<Integer, String>(topic, "message: " + i++));  
            try {  
                TimeUnit.SECONDS.sleep(1);  
            } catch (InterruptedException e) {  
                e.printStackTrace();  
            }  
        }  
    }  
  
    private Producer createProducer() {  
        Properties properties = new Properties();  
        properties.put("zookeeper.connect", "192.168.1.110:2181,192.168.1.111:2181,192.168.1.112:2181");//声明zk  
        properties.put("serializer.class", StringEncoder.class.getName());  
        properties.put("metadata.broker.list", "192.168.1.110:9092,192.168.1.111:9093,192.168.1.112:9094");// 声明kafka broker  
        return new Producer<Integer, String>(new ProducerConfig(properties));  
     }  
      
      
    public static void main(String[] args) {  
        new kafkaProducer("test").start();// 使用kafka集群中创建好的主题 test   
          
    }  
       
}  
  
  
  
  
3  kafka集群中消费主题test的数据:  
[root@h2master kafka]# bin/kafka-console-consumer.sh --zookeeper localhost:2181 --topic test --from-beginnin  
  
4   启动java代码,然后在看集群消费的数据如下:  
  
message: 0  
message: 1  
message: 2  
message: 3  
message: 4  
message: 5  
message: 6  
message: 7  
message: 8  
message: 9  
message: 10  
message: 11  
message: 12  
message: 13  
message: 14  
message: 15  
message: 16  
message: 17  
message: 18  
message: 19  
message: 20  
message: 21  

 2.kafka 使用Java写消费者,这样 先运行kafkaProducer ,在运行kafkaConsumer,即可得到生产者的数据:

import java.util.HashMap;  
import java.util.List;  
import java.util.Map;  
import java.util.Properties;  
  
import kafka.consumer.Consumer;  
import kafka.consumer.ConsumerConfig;  
import kafka.consumer.ConsumerIterator;  
import kafka.consumer.KafkaStream;  
import kafka.javaapi.consumer.ConsumerConnector;  
  
  
  
  
/** 
 * 接收数据 
 * 接收到: message: 10 
接收到: message: 11 
接收到: message: 12 
接收到: message: 13 
接收到: message: 14 
 * @author zm 
 * 
 */  
public class kafkaConsumer extends Thread{  
  
    private String topic;  
      
    public kafkaConsumer(String topic){  
        super();  
        this.topic = topic;  
    }  
      
      
    @Override  
    public void run() {  
        ConsumerConnector consumer = createConsumer();  
        Map<String, Integer> topicCountMap = new HashMap<String, Integer>();  
        topicCountMap.put(topic, 1); // 一次从主题中获取一个数据  
         Map<String, List<KafkaStream<byte[], byte[]>>>  messageStreams = consumer.createMessageStreams(topicCountMap);  
         KafkaStream<byte[], byte[]> stream = messageStreams.get(topic).get(0);// 获取每次接收到的这个数据  
         ConsumerIterator<byte[], byte[]> iterator =  stream.iterator();  
         while(iterator.hasNext()){  
             String message = new String(iterator.next().message());  
             System.out.println("接收到: " + message);  
         }  
    }  
  
    private ConsumerConnector createConsumer() {  
        Properties properties = new Properties();  
        properties.put("zookeeper.connect", "192.168.1.110:2181,192.168.1.111:2181,192.168.1.112:2181");//声明zk  
        properties.put("group.id", "group1");// 必须要使用别的组名称, 如果生产者和消费者都在同一组,则不能访问同一组内的topic数据  
        return Consumer.createJavaConsumerConnector(new ConsumerConfig(properties));  
     }  
      
      
    public static void main(String[] args) {  
        new kafkaConsumer("test").start();// 使用kafka集群中创建好的主题 test   
          
    }  
       
}  

 

分享到:
评论

相关推荐

    kafka搭建windows版本单机环境

    在本文中,我们将深入探讨如何在Windows操作系统上搭建Apache Kafka的单机环境。Apache Kafka是一款分布式流处理平台,常用于构建实时数据管道和流应用。Kafka以其高吞吐量、低延迟和容错性而著称,是大数据领域的...

    kafka集群搭建及测试.docx

    【Kafka集群搭建及测试】 Kafka是一种分布式流处理平台,常用于实时数据处理和大数据管道。本文档将详细介绍如何在三台Ubuntu 16虚拟机上搭建Kafka集群,并进行基本的测试,确保其正常运行。 **1. 准备工作** 在...

    kafka环境搭建(单机+集群) 详细

    在完成上述步骤后,你就成功地在单机和集群环境下搭建了Kafka和Redis。接下来,你可以开始测试消息传递和数据存储,了解如何创建主题,生产与消费消息,以及如何在Redis中存取数据。确保在实际使用中根据业务需求...

    windows下kafka_2.12-2.9.0.rar(含单机伪分布式配置)

    在分布式环境中,通常需要多台服务器来运行Kafka集群,但为了测试或学习目的,可以使用单机上的伪分布式设置,这使得开发者能够在本地环境中快速搭建Kafka实例,而无需复杂的网络配置。 标签中的“kafka”、...

    kafka搭建单机windows_单机linux_集群linux操作.rar

    《Kafka搭建详解:从Windows单机到Linux集群》 Kafka是一款由Apache开发的分布式流处理平台,常用于实时数据处理和消息传递。本文将详细介绍如何在Windows单机环境、Linux单机环境以及Linux集群环境下搭建Kafka,...

    kafka集群搭建文档

    本篇文档将详细介绍如何在Linux环境中搭建Kafka集群,同时结合Hadoop和Spark的分布式安装,构建一个完整的数据处理平台。 首先,搭建Kafka集群的基础条件包括: 1. 至少一台Linux服务器,但为了高可用性,推荐多台...

    快速部署单机kafka集群(win环境)

    另外本文是基于Windows部署的,Linux的步骤是基本相同的(只是启动脚本位置不同)。 kafka集群类型: single broker(单节点单boker集群,亦即kafka只启一个broker消息中间件服务,producer、consumer、broker均通过...

    kafka 单机集群搭建和监控

    在本文中,我们将深入探讨如何搭建Kafka单机环境与集群,以及如何进行有效的监控。Kafka是由Apache开发的一个分布式流处理平台,广泛应用于实时数据处理、消息传递和日志聚合等场景。以下是对每个主题的详细说明: ...

    kafka搭建资料及相关组件

    下面,我们将深入探讨Kafka的搭建过程及相关组件。 **一、Kafka的基本概念** 1. **主题(Topic)**:Kafka中的主题是数据的分类,类似于数据库的表,每个主题可以分为多个分区。 2. **分区(Partition)**:每个...

    kafka集群搭建.pdf

    kafka集群搭建方案 kafka集群搭建是大数据处理和实时数据处理的重要组件。下面是kafka集群搭建的详细方案: 一、准备工作 1. 关闭防火墙 关闭防火墙是kafka集群搭建的前提条件。可以使用systemctl disable ...

    kafka集群搭建与使用

    Kafka 集群搭建与使用 Kafka 是一种高吞吐量的分布式发布订阅消息系统,使用 Scala 编写。Kafka 拥有作为一个消息系统应该具备的功能,但是确有着独特的设计。Kafka 集群的搭建和使用是基于 Kafka 的设计理念和架构...

    向kafka插入数据测试

    这个场景中,我们关注的是“向Kafka插入数据”的测试。这涉及到多个知识点,包括Kafka的基本概念、生产者API、数据模型、以及如何进行测试。 1. **Kafka基本概念**:Kafka是一个高吞吐量、低延迟的消息队列系统,它...

    kafka 部署成windows服务

    总的来说,将Kafka部署成Windows服务是一项涉及多个步骤的任务,需要对Zookeeper、Kafka和Windows服务管理有一定的了解。通过遵循详细的安装启动教程,可以有效地在Windows环境中运行和管理Kafka服务,从而利用其...

    kafka环境搭建

    本文将详细介绍如何在Windows和Linux环境下搭建Kafka环境,并解释其中涉及的关键概念。 #### 二、Kafka基础知识 在开始环境搭建之前,我们先了解一些Kafka的基本术语: - **Broker**:Kafka 集群中的服务节点被...

    Kafka集群搭建(3台机)

    搭建Kafka集群涉及到对虚拟机的安装配置、JDK环境的搭建、Zookeeper的安装配置等关键步骤。下面详细介绍各个知识点。 首先,虚拟机的安装是搭建Kafka集群的基础。文中提到了使用VMWare来安装三台虚拟机,并分配了...

    windows的kafka配置及c++工程.zip

    本资源是windows下kafka的环境配置及c++实现的kafka的producer相关代码,启动后可以测试c++的producer发送消息可以在windows下启动的kafka的customer接收消息。

    kafka环境搭建并和spring整合

    这里我们将详细介绍如何搭建Kafka单机版环境,以及常用配置参数。 1. **单机版环境搭建** 单机版环境搭建相对简单,主要步骤包括下载安装包、配置环境变量等。 2. **集群版环境搭建** 集群版环境搭建较为复杂...

    kafka搭建与使用.doc

    Kafka 集群搭建与使用详解 Kafka 是一种分布式流媒体平台,由 Apache 开源项目提供。它主要用来构建实时数据管道和流媒体处理系统。本文档将详细介绍 Kafka 集群的搭建和使用,包括创建、删除、生产者、消费者等...

Global site tag (gtag.js) - Google Analytics