RocketMQ搭建(踩坑)指南
2020-03-23 本文已影响0人
三分归元币
官网
http://rocketmq.apache.org/docs/quick-start/
官方文档指引,首先从源码库直接下载源码文件,然后通过maven进行编译构建,期间需要很长一段时间,然后按照指引启动它的脚本文件。
坑位发掘
首先启动namesrv还是挺顺利的,到了broker,就开始第一个坑了
源码默认配置的虚拟机是8g的,本地跑就会导致allocate memory failed之类的错误。
打开同目录下的runbroker.sh文件,修改它的参数。
JAVA_OPT="${JAVA_OPT} -server -Xms256m -Xmx512m -Xmn125m"
终于启动正常了。
然后我们要观察启动日志,它将日志写到了~/logs 目录下。
data:image/s3,"s3://crabby-images/6d874/6d87426e3c7aa262638d5ec7b7d0265772edc5d2" alt=""
查看broker.log日志,发现如下图所示,则broker注册正常。
data:image/s3,"s3://crabby-images/7728d/7728d4d168d9064323d3048b8fe26261d02e7975" alt=""
或者使用如下命令,查看。
sh mqadmin clusterList -n localhost:9876
data:image/s3,"s3://crabby-images/9ba1d/9ba1daa15488ec93372c8d3d1f276ef928c28969" alt=""
然后我们写代码,写完生产消费者,发现启动又是一场,什么no route to Topic之类的,因为官网启动的时候没自动创建Topic,一顿折腾。
nohup sh bin/mqbroker -n localhost:9876 autoCreateTopicEnable=true -c conf/broker.conf &
下面这个命令,就是上面看到的clusterList中的clusterName,在其中添加一个topic testtopic。
sh mqadmin updateTopic -c DefaultCluster -n localhost:9876 -t testtopic
输入 sh mqadmin的时候,它会有文档指示的。
data:image/s3,"s3://crabby-images/d4911/d4911938df8ff3beaa4ae1580780b0ad84888f16" alt=""
data:image/s3,"s3://crabby-images/4a9c7/4a9c7651ca9b828a4bd025261150f56037855bb3" alt=""
关闭mq,脚本在编译好的rocketmq bin下
# 1.关闭Nameserver
sh mqshutdown namesrv
# 2.关闭Broker
sh mqshutdown broker
查看topic列表
sh mqadmin topicList -n 192.168.1.23:9876
删除topic
sh mqadmin deleteTopic –n localhost:9876 –c DefaultCluster –t toDelete
RocketMQ基本架构图
data:image/s3,"s3://crabby-images/17167/171676b98d185990d1c954627f904fb0b25dc42f" alt=""
nameserver负责协调broker信息,topic路由等,相当于注册中心。
每一个topic在broker上存在多个副本,每个broker上存在若干个queue控制并发度。每个queue是顺序消费。
Docker部署rocketmq
windows 安装docker toolbox
linux/macos 直接安装docker
pull 速度慢 换阿里云源
#拉取rocketmq
docker pull rocketmqinc/rocketmq
#拉取rocketmq控制台
docker pull styletang/rocketmq-console-ng
#windows下进入宿主机
docker-machine ssh
#启动nameserver
docker run -d -p 9876:9876 -v /opt/data/namesrv/logs:/root/logs -v /opt/data/namesrv/store:/root/store --name rmqnamesrv -e "MAX_POSSIBLE_HEAP=100000000" rocketmqinc/rocketmq sh mqnamesrv
#启动broker
docker run -d -p 10911:10911 -p 10909:10909 -v /opt/data/broker/logs:/root/logs -v /opt/rocketmq/data/broker/store:/root/store -v /opt/broker.conf:/opt/rocketmq/conf/broker.conf --name rmqbroker --link rmqnamesrv:namesrv -e "NAMESRV_ADDR=namesrv:9876" -e "MAX_POSSIBLE_HEAP=200000000" rocketmqinc/rocketmq sh mqbroker -c /opt/rocketmq/conf/broker.conf
#启动管理后台
docker run -e "JAVA_OPTS=-Drocketmq.config.namesrvAddr=192.168.99.100:9876 -Drocketmq.config.isVIPChannel=false" -p 8080:8080 -t styletang/rocketmq-console-ng
broker.conf
brokerClusterName = DefaultCluster
brokerName = broker-a
brokerId = 0
deleteWhen = 04
fileReservedTime = 48
brokerRole = ASYNC_MASTER
flushDiskType = ASYNC_FLUSH
brokerIP1 = {宿主机ip}
data:image/s3,"s3://crabby-images/bcd24/bcd242106862483c7ddb0d62bf1d7de282ddadb9" alt=""
源码启动
下载rocketmq的源码
data:image/s3,"s3://crabby-images/1d925/1d925e5f33a404d696c8918940a4595d3353c82d" alt=""
在idea添加启动参数
data:image/s3,"s3://crabby-images/e8dd5/e8dd58bfd56a27964750b61107fa8cc9506d4794" alt=""
创建好目录
data:image/s3,"s3://crabby-images/905d9/905d96afd4f06adc8463710d933e4c062b3ce2da" alt=""
拷贝配置文件
data:image/s3,"s3://crabby-images/a8f01/a8f01440a6458d3e34b739871c6726739f14141e" alt=""
# Licensed to the Apache Software Foundation (ASF) under one or more
# contributor license agreements. See the NOTICE file distributed with
# this work for additional information regarding copyright ownership.
# The ASF licenses this file to You under the Apache License, Version 2.0
# (the "License"); you may not use this file except in compliance with
# the License. You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
brokerClusterName = DefaultCluster
brokerName = broker-localhost
brokerId = 0
deleteWhen = 04
fileReservedTime = 48
brokerRole = ASYNC_MASTER
flushDiskType = ASYNC_FLUSH
brokerIP1 = 192.168.4.47
#配置存储位置
storePathRootDir=D:\\mqconf\\store
#commitlog 存储路径
storePathCommitLog=D:\\mqconf\\store\\commitlog
#消费队列存储路径
storePathConsumeQueue=D:\\mqconf\\store\\storestore\\consumequeue
#消息索引存储路径
storePathIndex=D:\\mqconf\\store\\index
#checkpoint文件存储路径
storeCheckPoint=D:\\mqconf\\store\\checkpoint
#abort文件存储路径
abortFile=D:\\mqconf\\store\\abort
data:image/s3,"s3://crabby-images/caaff/caaff16b5138488e9caa2507be16726ba48892d5" alt=""
data:image/s3,"s3://crabby-images/80dd2/80dd2be81b35984e336f208cc1228c9143c0782a" alt=""