https://www.cnblogs.com/blogxiao/p/13873275.html
《Docker 安装RocketMQ》

WSL Ubuntu 安装

首先安装JDK

  1. 安装jdk

    1. apt install openjdk-8-jre-headless -y
  2. 编辑 /ect/profile

    1. export JAVA_HOME=/usr/local/java
    2. export JRE_HOME=$JAVA_HOME/jre
    3. export CLASSPATH=.:$CLASSPATH:$JAVA_HOME/lib:$JRE_HOME/lib
    4. export PATH=$PATH:$JAVA_HOME/bin:$JRE_HOME/bin

    下载RocketMQ

    下载地址: http://rocketmq.apache.org/release_notes/release-notes-4.7.1/
    如图有两个版本,我们选择第二个,如果选择第一个源文件的话需要安装maven,需要自己编译。我们选择第二个就可以省略这一步骤了。
    image.png

    1. sudo unzip rocketmq-all-4.7.1-bin-release.zip
    2. sudo mv rocketmq-all-4.7.1-bin-release rocketmq
    3. sudo mv rocketmq /usr/local/rocketmq

    rocketmq/bin下的 runserver.sh 和runbroker.sh文件,把内存大小改小一点,因为我们的虚拟机内存没那么大
    image.png
    image.png

    修改日志目录

    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

然后再次验证,应该已经可以使用了。