部署架构
EMQ X 集群作为物联网接入服务(IoT Hub),部署在青云、AWS、阿里等公有云或企业私有云平台。
典型部署结构:
LB(负载均衡)
LB(负载均衡器)负责分发设备的 MQTT 连接与消息到 EMQ X 集群,LB 提高 EMQ X 集群可用性、实现负载平衡以及动态扩容。
部署架构推荐在 LB 终结 SSL 连接。设备与 LB 之间 SSL 安全连接,LB 与 EMQ X 之间 TCP 连接。这种部署模式下 EMQ X 单集群可轻松支持 100 万设备。
公有云厂商 LB 产品:
私有部署 LB 服务器:
国内公有云部署推荐青云(EMQ 合作伙伴),国外部署推荐 AWS。私有部署推荐使用 HAPRoxy 作为 LB。
EMQ X 集群
EMQ X 节点集群部署在 LB 之后,建议部署在 VPC 或私有网络内。公有云厂商青云、AWS、UCloud、QCloud 均支持 VPC 网络。
EMQ X 默认开启的 MQTT 服务 TCP 端口:
1883 | MQTT 协议端口 |
---|---|
8883 | MQTT/SSL 端口 |
8083 | MQTT/WebSocket 端口 |
8084 | MQTT/WebSocket(SSL)端口 |
8080 | 管理 API 端口 |
18083 | Dashboard 端口 |
防火墙根据使用的 MQTT 接入方式,开启上述端口的访问权限。
EMQ X 节点集群使用的 TCP 端口:
4369 | 集群节点发现端口 |
---|---|
5369 | 集群节点数据通道 |
6369 | 集群节点控制通道 |
集群节点间如有防护墙,需开启上述 TCP 端口互访权限。
青云(QingCloud)部署
创建 VPC 网络。
VPC 网络内创建 EMQ X 集群’私有网络’,例如: 192.168.0.0/24
私有网络内创建两台 EMQ X 主机,例如:
emqx1 | 192.168.0.2 |
---|---|
emqx2 | 192.168.0.3 |
安装并集群 EMQ X 主机,具体配置请参考安装集群章节。
创建 LB(负载均衡器)并指定公网 IP 地址。
在 LB 上创建 MQTT TCP 监听器:
或创建 SSL 监听器,并终结 SSL 在 LB:
- MQTT 客户端连接 LB 公网地址测试。
亚马逊(AWS)部署
创建 VPC 网络。
VPC 网络内创建 EMQ X 集群’私有网络’,例如: 192.168.0.0/24
私有网络内创建两台 EMQ X 主机,指定上面创建的 VPC 网络,例如:
emqx1 | 192.168.0.2 |
---|---|
emqx2 | 192.168.0.3 |
在安全组中,开放 MQTT 服务的 TCP 端口,比如 1883, 8883。
安装并集群 EMQ X 主机,具体配置请参考安装集群章节。
创建 ELB(Classic 负载均衡器),指定 VPC 网络,并指定公网 IP 地址。
在 ELB 上创建 MQTT TCP 监听器:
或创建 SSL 监听器,并终结 SSL 在 LB:
- MQTT 客户端连接 LB 公网地址测试。
阿里云部署
阿里云 LB 终结 SSL?
私有网络部署
EMQ X 集群直连
EMQ X 集群直接挂在 DNS,设备通过域名或者 IP 地址列表访问:
- 部署 EMQ X 集群,具体参考
程序包安装
与集群配置
文档。 - EMQ X 节点防火墙开启外部 MQTT 访问端口,例如 1883, 8883。
- 设备通过 IP 地址列表或域名访问 EMQ X 集群。
Tip
不推荐这种部署方式。
HAProxy -> EMQ X
HAProxy 作为 LB 部署 EMQ X 集群,并终结 SSL 连接:
- 创建 EMQ X 集群节点,例如:
节点 | IP 地址 |
---|---|
emqx1 | 192.168.0.2 |
emqx2 | 192.168.0.3 |
配置/etc/haproxy/haproxy.cfg,示例:
``` listen mqtt-ssl bind *:8883 ssl crt /etc/ssl/emqx/emqx.pem no-sslv3 mode tcp maxconn 50000 timeout client 600s default_backend emqx_nodes
backend emqx_nodes
mode tcp
balance source
timeout server 50s
timeout check 5000
server emqx1 192.168.0.2:1883 check inter 10000 fall 2 rise 5 weight 1
server emqx2 192.168.0.3:1883 check inter 10000 fall 2 rise 5 weight 1
source 0.0.0.0 usesrc clientip
```
NGINX Plus -> EMQ X
NGINX Plus 产品作为 EMQ X 集群的 LB,并终结 SSL 连接:
- 注册 NGINX Plus 试用版,Ubuntu 下安装: https://cs.nginx.com/repo_setup (opens new window)
- 创建 EMQ X 节点集群,例如:
节点 | IP 地址 |
---|---|
emqx1 | 192.168.0.2 |
emqx2 | 192.168.0.3 |
配置/etc/nginx/nginx.conf,示例:
stream {
# Example configuration for TCP load balancing
upstream stream_backend {
zone tcp_servers 64k;
hash $remote_addr;
server 192.168.0.2:1883 max_fails=2 fail_timeout=30s;
server 192.168.0.3:1883 max_fails=2 fail_timeout=30s;
}
server {
listen 8883 ssl;
status_zone tcp_server;
proxy_pass stream_backend;
proxy_buffer_size 4k;
ssl_handshake_timeout 15s;
ssl_certificate /etc/emqx/certs/cert.pem;
ssl_certificate_key /etc/emqx/certs/key.pem;
}
}