拉取rabbitmq镜像
拉取rabbitmq management镜像1
docker pull rabbitmq:3.7-rc-management
若不使用Rabbitmq的management功能,可以拉取镜像:rabbitmq:3.7-rc
参考:https://hub.docker.com/_/rabbitmq/
创建网络
创建rabbitmq私有网络
1 | # docker network create rabbitmqnet |
创建节点
通过docker命令创建三个Rabbitmq nodes;
注意这里使用相同的 RABBITMQ_ERLANG_COOKIE 值
1 | # docker run -d \ |
组建rabbitmq集群
登陆Rabbitmq的后两个节点,执行命令加入第一个Rabbitmq节点集群
1 | ### Disk Node |
退出集群
1 | # docker exec rabbitmq3 bash -c \ |
拉取haproxy镜像
拉取haproxy镜像
1 | # docker pull haproxy |
启动haproxy
1 | # cat haproxy-create.sh |
haproxy的配置文件如下:
1 | root@node0:~/rabbitmq# cat haproxy-etc/haproxy.cfg |
启动haproxy后,可以通过haproxy来访问rabbitmq集群:
获取haproxy的状态:
http://external-ip:1080/haproxy?stats
rabbitmq exporter部署
要收集rabbitmq的metrics给prometheus使用的话,可以使用开源的rabbitmq-exporter
参考如下:
https://github.com/kbudde/rabbitmq_exporter
https://hub.docker.com/r/kbudde/rabbitmq-exporter/
拉取镜像
1 | # docker pull kbudde/rabbitmq-exporter |
启动rabbitmq实例
1 | # docker run -d --name=rabbitmq1 -p 5672:5672 -p 15672:15672 -e RABBITMQ_NODENAME=rabbitmq1 -e RABBITMQ_ERLANG_COOKIE='YZSDHWMFSMKEMBDHSGGZ' -h rabbitmq1 --net=rabbitmqnet -p 9090:9090 rabbitmq:3.7-rc-management |
开启9090端口,这个是rabbitmq exporter的默认PUBLISH_PORT
启动rabbitmq exporter实例
1 | # docker run -d --net=container:rabbitmq1 kbudde/rabbitmq-exporter |
获取rabbitmq的metrics
1 | # wget http://localhost:9090/metrics |
rabbitmq相关端口
4369 (epmd), 25672 (Erlang distribution)
Epmd 是 Erlang Port Mapper Daemon 的缩写,在 Erlang 集群中相当于 dns 的作用,供给节点名称到端口的查询,epmd绑定在总所周知的4369端口上。
5672, 5671 (AMQP 0-9-1 without and with TLS)
AMQP,即 Advanced Message Queuing Protocol,一个提供统一消息服务的应用层标准高级消息队列协议,是应用层协议的一个开放标准,为面向消息的中间件设计。基于此协议的客户端与消息中间件可传递消息,并不受客户端/中间件不同产品,不同的开发语言等条件的限制。Erlang 中的实现有 RabbitMQ 等。
15672 (if management plugin is enabled)
通过
http://serverip:15672
访问 RabbitMQ 的 Web 管理界面,默认用户名密码都是 guest。(注意:RabbitMQ 3.0之前的版本默认端口是55672,下同)25672
管理插件端口,默认是AMQP端口+20000
61613, 61614 (if STOMP is enabled)
Stomp 是一个简单的消息文本协议,它的设计核心理念就是简单与可用性,官方文档,现在我们就来实践一下 Stomp 协议,你需要的是:
- 一个支持 stomp 消息协议的 messaging server (譬如activemq,rabbitmq)
- 一个终端(譬如linux shell)
- 一些基本命令与操作(譬如nc,telnet)
1883, 8883 (if MQTT is enabled)
MQTT 只是 IBM 推出的一个消息协议,基于 TCP/IP 的。两个 App 端发送和接收消息需要中间人,这个中间人就是消息服务器(比如ActiveMQ/RabbitMQ),三者通信协议就是 MQTT