前言
这篇文章以 4.3.0 版本为标准进行讲述在 linux 下部署 RocketMQ 单机实例,在此之前需要已配置 JAVA 环境。
apache RocketMQ 是阿里巴巴在 2016 年 11 月捐赠给了 apache 基金会并于 2017 年 9 月顺利毕业成为 apache 顶级项目。
下载程序包
直接使用一般就下载已经编译好的二进制文件就好了,下载好以后
> unzip rocketmq-all-4.3.0-bin-release.zip
> cd rocketmq-all-4.3.0-bin-release/
启动 name server
> nohup sh bin/mqnamesrv &
tail 一下日志看看是否已经启动成功
> tail -f ~/logs/rocketmqlogs/namesrv.log
The Name Server boot success...
启动 Broker
> nohup sh bin/mqbroker -n localhost:9876 &
tail 一下日志看看是否已经启动成功
> tail -f ~/logs/rocketmqlogs/broker.log
The broker[%s, 172.30.30.233:10911] boot success...
发送消息和接收消息
为了简单测试下,在发送/接收消息之前我们需要设置 NAMESRV_ADDR
环境变量
> export NAMESRV_ADDR=localhost:9876
发送消息,测试用例中的方式是使用 for 循环发送了 1000 条消息
> sh bin/tools.sh org.apache.rocketmq.example.quickstart.Producer
SendResult [sendStatus=SEND_OK, msgId= ...
接收消息
> sh bin/tools.sh org.apache.rocketmq.example.quickstart.Consumer
SendResult [sendStatus=SEND_OK, msgId= ...
关闭服务
> sh bin/mqshutdown broker
The mqbroker(36695) is running...
Send shutdown request to mqbroker(36695) OK
> sh bin/mqshutdown namesrv
The mqnamesrv(36664) is running...
Send shutdown request to mqnamesrv(36664) OK
到此,我们已经完成了一个简单的部署以及消息的发送和接收,但是这只是在内网下进行的收发消息。
FAQ
怎么修改 name server 和 broker 的启动内存?
一开始按照官网的步骤来操作往往会直接启动不起来,提示内存不足,那是因为 name server 和 broker 默认的启动 JVM 内存是 4G,而内存在不够的情况下自然就启动失败了。
这时候需要修改 name server 和 broker 的启动内存参数,
broker 的启动内存参数在 runbroker.sh
下修改,windows 下则是 runbroker.cmd
name server 的启动内存参数是在 runserver.sh
下修改,windows 下则是 runserver.cmd
需要配置外网访问要怎么配置呢?
在网上见过很多同学在配置外网访问的时候出现问题,得到的提示大多是
No Topic Route Info
这种提示一般都是连接失败了,
1.broker 没有允许自动创建 topic,且发送消息对应的 topic 不存在
2.broker 没有正确的连接到 name server
3.product 没有正确的连接到 name server
- 对于情况 1,在启动
broker
的时候添加autoCreateTopicEnable=true
参数就好了。 - 情况 2 呢,有可能是 name server 不存在或者是端口冲突,具体可以看日志的报错原因。
- 情况 3 的话,一般是端口原因,如果在服务器上本地收发消息都正常但是到了用客户端 sdk 发消息的时候失败了可以首先查看一下端口本地 ping 服务器的 9876 端口和 10911 端口是否正常,如果正常可以关闭 vip 通道再次尝试,以 JAVA 客户端的话就是下面这样
生产者关闭 VIP 通道:
producer.setVipChannelEnabled(false);
消费者关闭 VIP 通道:
consumer.setVipChannelEnabled(false);
关闭 VIP 通道为什么就可以了呢,是因为 VIP 通道占用了一个端口,10909 端口,而服务器的 10909 端口没有对外开放,所以导致失败了。
配置文件
这是我的 broker.properties
配置文件
brokerClusterName = DefaultCluster
brokerName = broker-a
brokerId = 0
deleteWhen = 04
fileReservedTime = 48
brokerRole = ASYNC_MASTER
flushDiskType = ASYNC_FLUSH
brokerIP1=172.17.59.146
brokerIP2=172.17.59.146
namesrvAddr=172.17.59.146:5776
autoCreateTopicEnable=true
因为我没有使用默认的 9876 端口,所以也有一个 name server 的配置文件,namesrv.conf
listenPort=5776
也可以直接下载我的 broker.properties 和 namesrv.conf
使用自己的配置文件启动 name server 和 broker 的时候都是添加一个指定文件的参数 -c 文件路径
到目前为止,一个简单的 apache RocketMQ 单机实例已经部署好了,开始愉快的消息队列旅程吧!
更多内容可以查看我的博客
欢迎来到这里!
我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。
注册 关于