https://www.cnblogs.com/blogxiao/p/13873275.html
《Docker 安装RocketMQ》
WSL Ubuntu 安装
首先安装JDK
安装jdk
apt install openjdk-8-jre-headless -y
编辑 /ect/profile
export JAVA_HOME=/usr/local/java
export JRE_HOME=$JAVA_HOME/jre
export CLASSPATH=.:$CLASSPATH:$JAVA_HOME/lib:$JRE_HOME/lib
export PATH=$PATH:$JAVA_HOME/bin:$JRE_HOME/bin
下载RocketMQ
下载地址: http://rocketmq.apache.org/release_notes/release-notes-4.7.1/
如图有两个版本,我们选择第二个,如果选择第一个源文件的话需要安装maven,需要自己编译。我们选择第二个就可以省略这一步骤了。sudo unzip rocketmq-all-4.7.1-bin-release.zip
sudo mv rocketmq-all-4.7.1-bin-release rocketmq
sudo mv rocketmq /usr/local/rocketmq
rocketmq/bin下的 runserver.sh 和runbroker.sh文件,把内存大小改小一点,因为我们的虚拟机内存没那么大
修改日志目录
sudo vim logback_namesrv.xml
sudo vim logback_broker.xml
修改{user.home}
rocketmq服务启动
进入rocketMQ解压目录下的bin文件夹
启动namesrv服务:nohup sh bin/mqnamesrv &
日志目录:{rocketMQ解压目录}/logs/rocketmqlogs/namesrv.log
启动broker服务:nohup sh bin/mqbroker -n localhost:9876 autoCreateTopicEnable=true &
日志目录:{rocketMQ解压目录}/logs/rocketmqlogs/broker.log
以上的启动日志可以在启动目录下的nohub.out中看到
rocketmq服务关闭
关闭namesrv服务:sh bin/mqshutdown namesrv
关闭broker服务 :sh bin/mqshutdown broker
rocketmq运行时提示 No route info of this topic 异常产生的原因可能是
①Broker禁止自动创建Topic,且用户没有通过手工方式创建Topic ②Broker没有正确连接到Name Server ③Producer没有正确连接到Name Server
首先解决①这种情况,启动顺序要先启动nameserver,再启动broker,启动broker时加上autoCreateTopicEnable=true
例如 nohup sh mqbroker -n localhost:9876 autoCreateTopicEnable=true &
启动没有异常检查下nameserver中是否成功注册了broker,有两种方式
第一种、看broker的日志 如果出现形如
2018-02-28 16:21:35 INFO BrokerControllerScheduledThread1 - register broker to name server 192.168.192.129:9876 OK
2018-02-28 16:22:05 INFO BrokerControllerScheduledThread1 - register broker to name server 192.168.192.129:9876 OK
证明已经连接到nameserver上
第二种、 在bin目录下执行命令sh mqadmin clusterList -n localhost:9876 如果看到
Cluster Name #Broker Name #BID #Addr #Version #InTPS(LOAD) #OutTPS(LOAD) #PCWait(ms) #Hour #SPACE
DefaultCluster DEFAULT_BROKER 0 192.168.192.129:10911 V4_2_0_SNAPSHOT 0.00(0,0ms) 0.00(0,0ms) 0 422168.55 -1.0000
也是证明已经连接到nameserver上。
如果按前两步检查没有问题,但启动还是报错,那么剩下的可能原因是producer无法连接到nameserver,很可能是防火墙的原因 ,要检验猜测只需要关闭防火墙,命令为systemctl stop firewalld.service
然后再次验证,应该已经可以使用了。