MongoDB 是一个免费的开源跨平台面向文档的 NoSQL 数据库程序。

1、查看可用的 Rocket MQ 版本

访问 Rabbitmq镜像库地址: Docker Hub

可以通过 Sort by 查看其他版本的 rabbitmq,默认是最新版本 rocketmq:latest

此外,我们还可以用 docker search rocketmq命令来查看可用版本

2、取最新版的 rocketmq镜像

这里我们拉取官方的最新版本的镜像:

docker pull apache/rocketmq:latest

3、查看本地镜像

使用以下命令来查看是否已安装了 rocketmq:

docker images

在上图中可以看到我们已经安装了最新版本(latest)的 rocketmq镜像。 

4. 创建映射文件的目录,并且赋予权限

sudo mkdir -p  /usr/local/rocketmq/data/namesrv/logs
sudo mkdir -p /usr/local/rocketmq/data/namesrv/store
#rocketmq下面所有子目录给予777权限
sudo chmod 777 -R /usr/local/rocketmq/

 (重要)这里把rocketmq的数据映射到磁盘,避免容器删除或者异常数据丢失。

 5.启动rocketmq mqnamesrv

安装完成后,我们可以使用以下命令来运行 rocketmq容器:

docker run -d --restart=always -p 9876:9876 -v /usr/local/rocketmq/data/namesrv/logs:/root/logs -v /usr/local/rocketmq/data/namesrv/store:/root/store --name rmqnamesrv -e "MAX_POSSIBLE_HEAP=100000000" apache/rocketmq sh mqnamesrv

6. 启动rocketmq broker

创建文件目录

sudo mkdir -p  /usr/local/rocketmq/conf
#rocketmq下面所有子目录给予777权限
sudo chmod 777 -R /usr/local/rocketmq/
touch broker.conf
vi broker.conf
# 配置如下
# 所属集群名称,如果节点较多可以配置多个
brokerClusterName = DefaultCluster 
#broker名称,master和slave使用相同的名称,表明他们的主从关系 
brokerName = broker-a 
#0表示Master,大于0表示不同的
slave brokerId = 0 
#表示几点做消息删除动作,默认是凌晨4点 
deleteWhen = 04 
#在磁盘上保留消息的时长,单位是小时 
fileReservedTime = 48 
#有三个值:SYNC_MASTER,ASYNC_MASTER,SLAVE;同步和异步表示Master和Slave之间同步数据的机 制;
brokerRole = ASYNC_MASTER 
#刷盘策略,取值为:ASYNC_FLUSH,SYNC_FLUSH表示同步刷盘和异步刷盘;SYNC_FLUSH消息写入磁盘后 才返回成功状态,ASYNC_FLUSH不需要;
flushDiskType = ASYNC_FLUSH 
# 设置broker节点所在服务器的ip地址 
brokerIP1 = 192.168.100.130 
#剩余磁盘比例 
diskMaxUsedSpaceRatio=99

 启动broker

docker run -d --restart=always -p 10911:10911 -p 10909:10909 -v /usr/local/rocketmq/data/broker/logs:/root/logs -v /usr/local/rocketmq/data/broker/store:/root/store -v /usr/local/rocketmq/conf/broker.conf:/opt/rocketmq/conf/broker.conf --name rmqbroker -e "NAMESRV_ADDR=namesrv:9876" -e "MAX_POSSIBLE_HEAP=200000000" apache/rocketmq sh mqbroker -c /opt/rocketmq/conf/broker.conf

4、启动rmqconsole

拉取镜像:

docker pull styletang/rocketmq-console-ng

 运行镜像:

docker run -d --name rmqconsole -p 9800:8080 -e "JAVA_OPTS=-Drocketmq.namesrv.addr=namesrv:9876 -Dcom.rocketmq.sendMessageWithVIPChannel=false" -t styletang/rocketmq-console-ng

注意一定要关闭防火墙:

Logo

权威|前沿|技术|干货|国内首个API全生命周期开发者社区

更多推荐