Docker 安装Rocket MQ
MongoDB 是一个免费的开源跨平台面向文档的 NoSQL 数据库程序。1、查看可用的 Rocket MQ 版本访问 Rabbitmq镜像库地址:Docker Hub。可以通过 Sort by 查看其他版本的 rabbitmq,默认是最新版本 rocketmq:latest。此外,我们还可以用 docker search rocketmq命令来查看可用版本2、取最新版的 rocketmq镜像这里
·
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
注意一定要关闭防火墙:
更多推荐
已为社区贡献1条内容
所有评论(0)