tag

  • 4.7.0
  • server-4.6.1 , broker-4.6.1
  • server-4.5.2 , broker-4.5.2
  • server-4.5.1 , broker-4.5.1
  • server-4.5.0 , broker-4.5.0

docker-rocketmq

rocketmq

rocketmq Version 4.5.1, 4.5.2 ,4.6.1 , 4.7.0

docker-rocketmq 镜像

4.7.0 版本镜像 将 不在根据base镜像生成 server,broker 镜像,统一使用 base 镜像,两者区别只是调用的 启动文件不同

一键部署 docker-compose

案例 版本 4.7.0

git clone  https://github.com/foxiswho/docker-rocketmq.git

cd docker-rocketmq

cd rmq


chmod +x  start.sh

./start.sh

访问浏览器

localhost:8180

注意 如果你的微服务或者项目在开发的时候没有放入docker中或者与rocketmq容器不能直接用IP访问, 那么请把broker.conf中的 #brokerIP1=192.168.0.253 前面#号去掉,并且把后面的IP地址改成你的rocketmq容器宿主机IP地址, 否则报 com.alibaba.rocketmq.remoting.exception.RemotingConnectException: connect to <172.0.0.120:10909> failed 配置文件 在 rmq/rmq/brokerconf 目录下

rocketmq 4.7.0 新版 启动

server

server 无日志目录映射

docker run -d \
      --name rmqnamesrv \
      -e "JAVA_OPT_EXT=-Xms512M -Xmx512M -Xmn128m" \
      -p 9876:9876 \
      foxiswho/rocketmq:4.7.0 \
      sh mqnamesrv

server 有日志目录映射

docker run -d -v $(pwd)/logs:/home/rocketmq/logs \
      --name rmqnamesrv \
      -e "JAVA_OPT_EXT=-Xms512M -Xmx512M -Xmn128m" \
      -p 9876:9876 \
      foxiswho/rocketmq:4.7.0 \
      sh mqnamesrv

broker

broker 无 目录映射

docker run -d \
      --name rmqnamesrv \
      -e "JAVA_OPT_EXT=-Xms512M -Xmx512M -Xmn128m" \
      -p 9876:9876 \
      foxiswho/rocketmq:4.7.0 \
      sh mqbroker -c /home/rocketmq/conf/broker.conf

broker 目录映射

docker run -d  -v $(pwd)/logs:/home/rocketmq/logs -v $(pwd)/store:/home/rocketmq/store \
      -v $(pwd)/conf:/home/rocketmq/conf \
      --name rmqbroker \
      -e "NAMESRV_ADDR=rmqnamesrv:9876" \
      -e "JAVA_OPT_EXT=-Xms512M -Xmx512M -Xmn128m" \
      -p 10911:10911 -p 10912:10912 -p 10909:10909 \
      foxiswho/rocketmq:4.7.0 \
      sh mqbroker -c /home/rocketmq/conf/broker.conf

以下为 4.7.0以前 旧版启动

单个测试案例

server

docker run -d -p 9876:9876 --name rmqserver  foxiswho/rocketmq:server

broker

docker run -d -p 10911:10911 -p 10909:10909 --name rmqbroker \
--link rmqserver:rmqserver \
-e "NAMESRV_ADDR=rmqserver:9876" \
-e "JAVA_OPT_EXT=-server -Xms128m -Xmx128m -Xmn128m -Duser.home=/opt" \
foxiswho/rocketmq:broker

broker 配置文件位置 (容器内)

/etc/rocketmq/broker.conf

如果要使用自己的配置文件

如果要使用自己的配置文件,那么先把你以前创建好的 容器 rmqbroker ,先删除 然后再执行 如下 请全部复制到shell 中执行

docker run -d -p 10911:10911 -p 10909:10909 --name rmqbroker --link rmqserver:rmqserver \
-e "NAMESRV_ADDR=rmqserver:9876" \
-e "JAVA_OPT_EXT=-server -Xms128m -Xmx128m -Xmn128m -Duser.home=/opt" \
-v /User/fox/rmq/conf/broker.conf:/etc/rocketmq/broker.conf \
foxiswho/rocketmq:broker

/User/fox/rmq/conf/broker.conf 为我的本地配置文件目录,把他替换成你自己的就可以了

注意(重要的事说3遍)

注意(重要的事说3遍)

注意(重要的事说3遍)

如果你的微服务没有使用docker,那么需要把/etc/rocketmq/broker.conf 配置文件中的brokerIP1=192.168.0.253 这个启用,IP 地址填写 你docker 所在 宿主机的IP ,否则报错

console

来自 https://hub.docker.com/r/styletang/rocketmq-console-ng/

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

浏览器访问

localhost:8180

Example:

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

其他案例

https://github.com/foxiswho/docker-nacos-sentinel-rocketmq-rabbitmq

https://github.com/foxiswho/docker-consul-fabio-apollo-rocketmq-rabbitmq

K8S 案例

https://github.com/foxiswho/k8s-nacos-sentinel-rocketmq-zipkin-elasticsearch-redis-mysql