您的位置:首页 > 运维架构 > Linux

Kafka linux集群部署

2016-06-05 20:46 411 查看

配置环境

win7旗舰版
虚拟机 oracle vm virtualBox5.0
jdk 1.7.0_79
zookeeper-3.4.6 (配置好的可以参考上一篇zookeeper的集群配置)
kafka_2.10-0.8.2.2


准备工作

下载kafka 官网地址http://kafka.apache.org/downloads.html
# wget http://mirror.bit.edu.cn/apache/kafka/0.8.2.2/kafka_2.10-0.8.2.2.tgz 解压到root 根目录
# tar -zxvf package/kafka_2.10-0.8.2.2.tgz


修改配置文件

进入kafka conf目录下
# cd /root/kafka_2.10-0.8.2.2/config
查看配置文件
# ll
-rw-r--r-- 1 root root 1199  9月  3  2015 consumer.properties
-rw-r--r-- 1 root root 3846  9月  3  2015 log4j.properties
-rw-r--r-- 1 root root 2228  9月  3  2015 producer.properties
-rw-r--r-- 1 root root 5559  9月  3  2015 server.properties
-rw-r--r-- 1 root root 3325  9月  3  2015 test-log4j.properties
-rw-r--r-- 1 root root  993  9月  3  2015 tools-log4j.properties
-rw-r--r-- 1 root root 1023  9月  3  2015 zookeeper.properties

主要修改server.properties  修改一些默认的配置和最后三行加入一些配置

在kafka 根目录下创建三个文件夹server0,server1,server2
复制 默认config的配置文件到三个文件夹下为创建集群做准备
#cp -f config server0
#cp -f config server1
#cp -f config server2
然后修改server0 下的server.properties 对应的配置地方修改
#节点标识
broker.id=0
#端口号
port=9092
#本机ip
host.name=192.168.1.181
num.network.threads=3
num.io.threads=8
socket.send.buffer.bytes=1024000
socket.request.max.bytes=104857600
#日志文件存放
log.dirs=/root/kafka_2.10-0.8.2.2/server0/kafkalogs0
num.partitions=2
num.recovery.threads.per.data.dir=1
log.retention.hours=168
log.segment.bytes=536870912
log.retention.check.interval.ms=300000
log.cleaner.enable=false
zookeeper.connection.timeout.ms=6000
#关联的zookeeper集群 当然可以指定多个 以逗号分隔
zookeeper.connect=192.168.1.181:2181
message.max.bytes = 5048576
default.replication.factor = 2
replica.fetch.max.bytes = 5048576

server1/config/server.properties 复制server0 要修改下边
broker.id=1
port=9082
log.dirs=/root/kafka_2.10-0.8.2.2/server1/kafkalogs1
server2/config/server.properties 复制server0 要修改下边
broker.id=2
port=9072
log.dirs=/root/kafka_2.10-0.8.2.2/server2/kafkalogs2

后台启动项目
#bin/kafka-server-start.sh -daemon server0/config/server.properties
#bin/kafka-server-start.sh -daemon server1/config/server.properties
#bin/kafka-server-start.sh -daemon server2/config/server.properties

看下kafka进程
# jps
12703 QuorumPeerMain
14328 Jps
14040 Kafka
13978 Kafka
14286 Kafka
这种情况标识三个kafka服务启动成功了

测试消息发布和接受
创建话题
# bin# ./kafka-topics.sh --create --zookeeper 192.168.1.181:2181 --replication-factor 2 --partitions 2 --topic test
查看话题
# bin# ./kafka-topics.sh --list --zookeeper 192.168.1.181:2181
开启一个消费者准备接受消息 可以接收多个话题用逗号分隔
#bin# ./kafka-console-consumer.sh --zookeeper 192.168.1.181:2181 --topic test --from-beginning
开启一个生产者发送消息
#bin#  /kafka-console-producer.sh --broker-list 192.168.1.181:9092 --topic test
发送message
消费端窗口就会出现message
再多开几个生产者试试别的端口是否可用。


到这里就结束了,集群基本上时可用的,接下来学习java客户端操作消息队列数据
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: