1.下线操作
1.步骤一
新建一个文件名为topics-to-move.json
文件内容为需要转移的topic
{"topics": [
{"topic": "__consumer_offsets"},
{"topic": "click_stream_topic"},
{"topic": "directory_topic"},
{"topic": "DP_monitor_consumer_topic"},
{"topic": "DP_monitor_provider_topic"},
{"topic": "EC_user_event_rt_topic"},
{"topic": "kafka_topic"}
],
"version":1
}
2.步骤二
执行以下操作命令,比如下线0号机器,把0上的数据都移到1,2上,脚本内容
bin/kafka-reassign-partitions.sh --zookeeper localhost:2181 --topics-to-move-json-file topics-to-move.json --broker-list "1,2" --generate
data:image/s3,"s3://crabby-images/6e2f8/6e2f83ab0c81b7cbfff9ed827aa6b504d629f8d0" alt=""
将新生产的json串赋值到
expand-cluster-reassignment.json
文件中,
data:image/s3,"s3://crabby-images/59a42/59a42d402133451cd5b71565ef343ed295f16f2b" alt=""
3.步骤三
开始执行转移数据操作
bin/kafka-reassign-partitions.sh --zookeeper localhost:2181 --reassignment-json-file expand-cluster-reassignment.json --execute
data:image/s3,"s3://crabby-images/52a73/52a73f8d11cdc4575308ca7dbac55a401cd3aca9" alt=""
使用以下命令查看状态
bin/kafka-reassign-partitions.sh --zookeeper localhost:2181 --reassignment-json-file expand-cluster-reassignment.json --verify
效果,如下图所示,数据转移完成
data:image/s3,"s3://crabby-images/89f72/89f726dcf1b23b2c0a801e0bb6762e8ace3f43cb" alt=""
按照上述步骤将所有的0上的topic都转移到1,2服务器上,0号机器下线升级系统
2.上线操作
与下线操作原理一样
1.步骤一
执行以下操作命令,把数据都转移到0,1,2上,执行以下脚本
bin/kafka-reassign-partitions.sh --zookeeper localhost:2181 --topics-to-move-json-file topics-to-move.json --broker-list "0,1,2" --generate
data:image/s3,"s3://crabby-images/78622/78622674b2dd04fa7f441ec636b5d9f714b70343" alt=""
2.将内容copy到expand-cluster-reassignment2.json
文件中,执行以下命令
bin/kafka-reassign-partitions.sh --zookeeper localhost:2181 --reassignment-json-file expand-cluster-reassignment2.json --execute
data:image/s3,"s3://crabby-images/53018/53018390f4e9f27666257b86fd71b93666a8e70a" alt=""
使用以下命令查看状态
bin/kafka-reassign-partitions.sh --zookeeper localhost:2181 --reassignment-json-file expand-cluster-reassignment2.json --verify
data:image/s3,"s3://crabby-images/cc91d/cc91dec6334bba72d13433e9719725e28bcb6122" alt=""
效果数据恢复
data:image/s3,"s3://crabby-images/bd788/bd7883b9320e1f4c77eb92edde8f842f8829c33e" alt=""
3.总结
测试环境数据量较少,转移非常快,线上环境,topic较多,partitions数量也多,转移数据较慢,一次不要操作太多topic,需要耐心等待观察。
网友评论