Kafka知识体系
Centos7安装与配置Kafka
# yum安装java环境
# 下载并解压Kafka
wget http://mirror.bit.edu.cn/apache/kafka/2.3.0/kafka_2.11-2.3.0.tgz
tar -xf kafka_2.11-2.3.0.tgz
# 移动到合理位置
mv kafka_2.11-2.3.0 /opt/kafka2.11
# 配置系统环境变量
echo "export KAFKA_HOME=/opt/kafka2.11" >> /etc/profile
echo "export PATH=$PATH:$KAFKA_HOME/bin" >> /etc/profile
source /etc/profile
# 测试Kafka,一定要优先启动Zookeeper
# 我这里10.10.10.18:2181端口上是我的Zookeeper,也可以参见下面的配置文件
kafka-server-start.sh -daemon /opt/kafka2.11/config/server.properties
# 查看是否启动成功
jps -m
配置Kafka
vim /opt/kafka2.11/config/server.properties
# 节点名称
broker.id=0
# 绑定地址
listeners=PLAINTEXT://PLAINTEXT:9092
# 当kafka在docker或者虚拟机中时,需要使用以下参数
advertised.listeners=PLAINTEXT://kafka-server:9092
# 发送缓存字节数
socket.send.buffer.bytes=102400
# 接收缓存字节数
socket.receive.buffer.bytes=102400
# 最大请求字节数,保护OOM
socket.request.max.bytes=104857600
# 日志目录
log.dirs=/tmp/kafka-logs
# 默认分区数
num.partitions=1
# zookeeper地址
zookeeper.connect=10.10.10.19:2181
# zookeeper连接超时时间,单位毫秒
zookeeper.connection.timeout.ms=6000
单机版Kafka
在一台服务器上,启动一次即可。
集群版Kafka
- 单节点,多Broker
在一台服务器上,启动多次Kafka,没次启动加载的配置文件需要不一致,并且配置文件中的broker_id的值也需要不一致且每个值唯一。
kafka-server-start.sh -daemon /opt/kafka2.11/config/server_1.properties # 对应broker=1
kafka-server-start.sh -daemon /opt/kafka2.11/config/server_2.properties # 对应broker=2
- 多节点,多Broker
在多台服务器启动单个broker;在多台服务器上启动多个broker。
清理Kafka日志
在配置文件中,有参数可以进行控制:vim /opt/kafka2.11/config/server.properties
log.retention.hours=1 # 日志保留时间(h)
log.retention.minutes=60 # 日志保留时间(m)
log.retention.ms=3600000 # 日志保留时间(s)
# 也可以使用其它配置
log.retention.bytes=1073741824 # 日志保留大小(bytes)
使用Kafka
备注 | 命令 |
---|---|
创建topic | kafka-topics.sh --zookeeper 10.10.10.19:2181 --create --replication-factor 1 --partitions 1 --topic topic_name |
列举topic | kafka-topics.sh --zookeeper 10.10.10.19:2181 --list |
查看topic详情 | kafka-topics.sh --zookeeper 10.10.10.19:2181 --describe --topic topic_name |
修改topic分区 | kafka-topics.sh --zookeeper 10.10.10.19:2181 --alter --partitions 20 --topic topic_name |
删除topic | kafka-topics.sh --zookeeper 10.10.10.19:2181 --delete --topic topic_name |
启动消费者 | kafka-console-consumer.sh --zookeeper 10.10.10.19:2181 --topic topic_name |
启动生产者 | kafka-console-producer.sh --broker-list 10.10.10.19:9092 --topic topic_name |
指定消费者从头消费 | --from-beginning |
踩坑
删除topic时报错
Note: This will have no impact if delete.topic.enable is not set to true.
解决方案:修改配置
# vim /opt/kafka2.11/config/server.properties
delete.topic.enble=true