zoukankan      html  css  js  c++  java
  • Kafka0.10.2.0分布式集群安装

    一、依赖文件安装

        1.1 JDK

             参见博文:http://www.cnblogs.com/liugh/p/6623530.html

        1.2 Scala

             参见博文:http://www.cnblogs.com/liugh/p/6624491.html

        1.3 Zookeeper

             参见博文:http://www.cnblogs.com/liugh/p/6671460.html

    二、文件准备

         2.1 文件名称

           kafka_2.11-0.10.2.0.tgz 

         2.2 下载地址

           http://kafka.apache.org/downloads

        

    三、工具准备

        3.1 Xshell

          一个强大的安全终端模拟软件,它支持SSH1, SSH2, 以及Microsoft Windows 平台的TELNET 协议。

          Xshell 通过互联网到远程主机的安全连接以及它创新性的设计和特色帮助用户在复杂的网络环境中享受他们的工作。

        3.2 Xftp

         一个基于 MS windows 平台的功能强大的SFTPFTP 文件传输软件。

        使用了 Xftp 以后,MS windows 用户能安全地在UNIX/Linux 和 Windows PC 之间传输文件。

    四、部署图

    五、Kafka安装

        以下操作,均使用root用户

       5.1 通过Xftp将下载下来的Kafka安装文件上传到Master及两个Slave的/usr目录下

       5.2 通过Xshell连接到虚拟机,在Master及两个Slave上,执行如下命令,解压文件:

            # tar zxvf kafka_2.11-0.10.2.0.tgz 

       5.3 在Master上,使用Vi编辑器,设置环境变量

            # vi /etc/profile

            在文件最后,添加如下内容:       

    #Kafka Env

    export KAFKA_HOME=/usr/kafka_2.11-0.10.2.0
    export PATH=$PATH:$KAFKA_HOME/bin

       5.4 退出vi编辑器,使环境变量设置立即生效

           # source /etc/profile

           通过scp命令,将/etc/profile拷贝到两个Slave节点:

           #scp /etc/profile root@DEV-SH-MAP-02:/etc

           #scp /etc/profile root@DEV-SH-MAP-03:/etc

           分别在两个Slave节点上执行# source /etc/profile使其立即生效

    六、Kafka配置

        以下操作均在Master节点,配置完后,使用scp命令,将配置文件拷贝到两个Slave节点即可。

       6.1 server.properties配置文件

        切换到/usr/kafka_2.11-0.10.2.0/config目录下

        使用vi编辑器,打开server.properties,主要设置BrokerId、listeners、LogDir、Zookeeper,如下所示:

    broker.id=1
    
    listeners=PLAINTEXT://DEV-SH-MAP-01:9092
    
    log.dirs=/usr/kafka_2.11-0.10.2.0/log
    
    zookeeper.connect=DEV-SH-MAP-01:2181,DEV-SH-MAP-02:2181,DEV-SH-MAP-03:2181

         其中:

           1)broker.id:broker的id,必需是一个全局(集群)唯一的整数值,即集群中每个kafka server的配置不能相同

           2)listeners:socket监听的地址,格式为listeners = security_protocol://host_name:port,端口默认为9092 

           3)log.dirs:日志保存目录

           4)zookeeper.connect:zookeeper连接地址

       拷贝配置文件到两个Slave节点:

       在Master节点,执行如下命令:   

       # scp server.properties root@DEV-SH-MAP-02:/usr/kafka_2.11-0.10.2.0/config

       # scp server.properties root@DEV-SH-MAP-03:/usr/kafka_2.11-0.10.2.0/config

      【注意】需要结合具体的Slave节点,修改borker.Id、listeners

    七、Kafka使用

       7.1 启动Kafka集群

           分别在Master及两个Slave上执行命令:

           kafka-server-start.sh -daemon server.properties

      7.2 创建Topic

         kafka-topics.sh --zookeeper DEV-SH-MAP-01:2181 --create --replication-factor 1 --partitions 1 --topic test

     7.3 查看Topic

         kafka-topics.sh --zookeeper DEV-SH-MAP-01:2181 --list

     7.4 创建Producer

          kafka-console-producer.sh --broker-list DEV-SH-MAP-01:9092 --topic test

     7.5 创建Consumer

          kafka-console-consumer.sh --bootstrap-server DEV-SH-MAP-01:9092 --topic test --from-beginning

     7.6 删除Topic

          kafka-topics.sh --zookeeper DEV-SH-MAP-01:2181 --delete --topic test

  • 相关阅读:
    数据库表与视图的区别
    maven中snapshot版本和正式版本的区别
    @Retention注解
    java泛型以及通配符
    git 删除了本不应该删除的commit 如何恢复
    ES group分组聚合的坑
    solution for 1006 中国剩余定理
    solution for POJ 1001
    ondraw() 和dispatchdraw()的区别
    android几种定时器机制及区别(转载整理)
  • 原文地址:https://www.cnblogs.com/liugh/p/6691589.html
Copyright © 2011-2022 走看看