RocketMQ-单机版安装与启动详细步骤

目录:
一. RocketMQ-单机版安装与启动详细步骤
二.安装时候遇到的问题及解决
三.安装管理控制台

转载于:RocketMQ-单机版安装与启动详细步骤

下载:rocketmq-all-4.9.4-bin-release.zip

解压到/usr/local/目录下

进入到 /usr/local/rocketmq-all-4.9.4-bin-release/ 目录

启动NameServer
sh bin/mqnamesrv
tail -f ~/logs/rocketmqlogs/namesrv.log
​启动broker
sh bin/mqbroker -n localhost:9876
tail -f ~/logs/rocketmqlogs/broker.log
发送/接收消息测试

发送消息

export NAMESRV_ADDR=localhost:9876 
sh bin/tools.sh org.apache.rocketmq.example.quickstart.Producer

​接收消息

sh bin/tools.sh org.apache.rocketmq.example.quickstart.Consumer
关闭Server

无论是关闭 name server 还是 broker ,都是使用 bin/mqshutdown 命令。

[root@mqOS rocketmq]# sh bin/mqshutdown broker 
The mqbroker(1740) is running... 
Send shutdown request to mqbroker(1740) OK 

[root@mqOS rocketmq]# sh bin/mqshutdown namesrv 
The mqnamesrv(1692) is running... 
Send shutdown request to mqnamesrv(1692) OK 
[2]+ 退出 143 nohup sh bin/mqbroker -n localhost:9876

安装时候遇到的问题

1、rocketmq访问时出现 No route info of this topic 异常产生的原因:
  • Broker禁止自动创建Topic,且用户没有通过手工方式创建Topic
  • Broker没有正确连接到Name Server
  • Producer没有正确连接到Name Server (防火墙问题)
第一种情况解决方法 Broker禁止自动创建Topic,且用户没有通过手工方式创建Topic

sh bin/mqbroker -m 来查看 broker 的配置参数
如下所示,autoCreateTopicEnable=true 证明是没有问题的

[root@localhost apache-rocketmq]# sh ./bin/mqbroker -m
2018-08-12 01\:27\:28 INFO main - namesrvAddr=
2018-08-12 01\:27\:28 INFO main - brokerIP1=192.168.58.129
2018-08-12 01\:27\:28 INFO main - brokerName=localhost.localdomain
2018-08-12 01\:27\:28 INFO main - brokerClusterName=DefaultCluster
2018-08-12 01\:27\:28 INFO main - brokerId=0
2018-08-12 01\:27\:28 INFO main - autoCreateTopicEnable=true
2018-08-12 01\:27\:28 INFO main - autoCreateSubscriptionGroup=true
2018-08-12 01\:27\:28 INFO main - rejectTransactionMessage=false
2018-08-12 01\:27\:28 INFO main - fetchNamesrvAddrByAddressServer=false
2018-08-12 01\:27\:28 INFO main - transactionTimeOut=3000
2018-08-12 01\:27\:28 INFO main - transactionCheckMax=5
2018-08-12 01\:27\:28 INFO main - transactionCheckInterval=60000
2018-08-12 01\:27\:28 INFO main - storePathRootDir=/root/store
2018-08-12 01\:27\:28 INFO main - storePathCommitLog=/root/store/commitlog
2018-08-12 01\:27\:28 INFO main - flushIntervalCommitLog=500
2018-08-12 01\:27\:28 INFO main - commitIntervalCommitLog=200
2018-08-12 01\:27\:28 INFO main - flushCommitLogTimed=false
2018-08-12 01\:27\:28 INFO main - deleteWhen=04
2018-08-12 01\:27\:28 INFO main - fileReservedTime=72
2018-08-12 01\:27\:28 INFO main - maxTransferBytesOnMessageInMemory=262144
2018-08-12 01\:27\:28 INFO main - maxTransferCountOnMessageInMemory=32
2018-08-12 01\:27\:28 INFO main - maxTransferBytesOnMessageInDisk=65536
2018-08-12 01\:27\:28 INFO main - maxTransferCountOnMessageInDisk=8
2018-08-12 01\:27\:28 INFO main - accessMessageInMemoryMaxRatio=40
2018-08-12 01\:27\:28 INFO main - messageIndexEnable=true
2018-08-12 01\:27\:28 INFO main - messageIndexSafe=false
2018-08-12 01\:27\:28 INFO main - haMasterAddress=
2018-08-12 01\:27\:28 INFO main - brokerRole=ASYNC_MASTER
2018-08-12 01\:27\:28 INFO main - flushDiskType=ASYNC_FLUSH
2018-08-12 01\:27\:28 INFO main - cleanFileForciblyEnable=true
2018-08-12 01\:27\:28 INFO main - transientStorePoolEnable=false

先将已有服务关闭

# 1.关闭Nameserver
sh bin/mqshutdown namesrv
# 2.关闭Broker
sh bin/mqshutdown broker

然后顺序启动nameserver

# 1.启动nameserver
nohup sh bin/mqnamesrv &
# 2.查看启动日志
tail -f ~/logs/rocketmqlogs/namesrv.log

再启动broker,启动broker的时候可以进行手动或者自动添加topic

自动:启动broker时加上autoCreateTopicEnable=true

nohup sh mqbroker -n localhost:9876 autoCreateTopicEnable=true &

启动没有异常的情况下,检查下nameserver中是否成功注册了broker
查看broker日志内容:
在这里插入图片描述

手动:正常启动broker,再执行创建

# 1.启动Broker
nohup sh bin/mqbroker -n localhost:9876 &
# 2.查看启动日志
tail -f ~/logs/rocketmqlogs/broker.log

# 先查看有没有topic
sh bin/mqadmin topicList -n localhost:9876
# 或者查看详情
sh bin/mqadmin topicstatus -n localhost:9876 -t test_topic
* test_topic是topic名称

# 手动新增topic
sh mqadmin updateTopic -n localhost:9876  -b localhost:10911  -t test_topic	
* 加完后记得查看一下是否加成功了

第二种情况解决方法 Broker没有正确连接到Name Server

如下所示,启动 broker 的时候,只要看到了 The broker[localhost.localdomain, 192.168.58.129:10911] boot success. serializeType=JSON and name server is localhost:9876 字样就说明是成功的

[root@localhost apache-rocketmq]# nohup sh bin/mqbroker -n localhost:9876 &
[2] 3256
[1] 退出 143 nohup sh bin/mqbroker -n localhost:9876
[root@localhost apache-rocketmq]# nohup: 忽略输入并把输出追加到"nohup.out"
tail -f ~/logs/rocketmqlogs/broker.log
2018-08-11 23:48:26 INFO main - load exist subscription group, SubscriptionGroupConfig [groupName=CID_ONSAPI_OWNER, consumeEnable=true, consumeFromMinEnable=true, consumeBroadcastEnable=true, retryQueueNums=1, retryMaxTimes=16, brokerId=
2018-08-11 23:48:31 WARN main - Load default discard message hook service: DefaultTransactionalMessageCheckListener
2018-08-11 23:48:31 INFO FileWatchService - FileWatchService service started
2018-08-11 23:48:31 INFO PullRequestHoldService - PullRequestHoldService service started
2018-08-11 23:48:31 INFO brokerOutApi_thread_1 - register broker to name server localhost:9876 OK
2018-08-11 23:48:31 INFO main - Start transaction service!
2018-08-11 23:48:31 INFO main - The broker[localhost.localdomain, 192.168.58.129:10911] boot success. serializeType=JSON and name server is localhost:9876
2018-08-11 23:48:41 INFO BrokerControllerScheduledThread1 - dispatch behind commit log 0 bytes
2018-08-11 23:48:41 INFO BrokerControllerScheduledThread1 - Slave fall behind master: 906412 bytes
2018-08-11 23:48:41 INFO brokerOutApi_thread_2 - register broker to name server localhost:9876 OK

查看是否连接正确,执行命令

sh bin/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.1.128:10911    V4_5_1          0.00(0,0ms)        0.00(0,0ms)          0 1847.32 0.5485

否则就是broker或者namesrv启动有问题,大部分都是brokerIP1=192.168.1.128 没有配置正确。需要去conf/broker.conf修改一下brokerIP1,然后再走一遍正常启动流程就可以了

第三种情况解决方法 Producer没有正确连接到Name Server (防火墙问题)

如果按前两步检查没有问题,但启动还是报错,那就只剩下第三种情况了,最大可能是发送者和mq服务器之间的网络或端口不通,可以使用ping或者telnet确定问题。如果ping或者telnet连接不通,则说明producer无法连接到nameserver,很可能是防火墙的原因 ,需要联系运维工程师开通网络或端口权限。

如果是防火墙的原因 ,需要关闭防火墙,命令为

# 停止防火墙
systemctl stop firewalld.service
# 禁用防火墙
systemctl disable firewalld.service
* 禁用会使得下次开机不会自启
2、service not available now. It may be caused by one of the following reasons: the broker’s disk is full

最后加一行diskMaxUsedSpaceRatio=99(所有节点的配置文件都加一下),表示剩余磁盘比例不足99才报错

vi bin/runbroker.sh

在里面增加一行

JAVA_OPT="${JAVA_OPT} -Drocketmq.broker.diskSpaceWarningLevelRatio=0.99"

安装管理控制台

发现https://github.com/apache/rocketmq-externals这个git项目上并没有找到rocketmq-console这个目录,之前的rocket-console已经不在这个仓库了,已经创建了一个独立的仓库并命名为RocketMQ Dashboard。

我们进入到这个dashboard仓库:https://github.com/apache/rocketmq-dashboard。
clone完成之后,可以看到目录,这是一个springboot项目。

修改配置文件
我们进入到rocketmq-dashboard-master/src/main/resources 这个目录下,然后查看application.properties这个文件。

我们可以将“server.port=8080” 这个端口配置修改一下,修改成8888.

其次需要注意这里的“rocketmq.config.namesrvAddr=”配置,即需要设置自己的rocketmq的name服务的地址和端口号。默认端口号是9876。

rocketmq.config.namesrvAddr=192.168.131.171:9876

使用maven编译打包项目

mvn clean package -Dmaven.test.skip=true  
cd /Users/your_user_name/.m2/repository/com/github/eirslett/yarn/1.22.10
mv yarn-v1.22.10.tar.gz yarn-1.22.10.tar.gz

注意:使用浏览器下载下来的文件名是yarn-v1.22.10.tar.gz,拷贝放到maven目录的文件名须是yarn-1.22.10.tar.gz。

进入target目录

java -jar rocketmq-dashboard-1.0.1-SNAPSHOT.jar

在这里插入图片描述

参考链接:
1、https://blog.csdn.net/weixin_45937536/article/details/123710826
2、https://www.cnblogs.com/lingyejun/p/16369083.html
3、https://blog.csdn.net/bufegar0/article/details/108720482

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值