Docker部署EMQX

1、简介

EMQ X (Erlang/Enterprise/Elastic MQTT Broker) 是基于 Erlang/OTP 平台开发的开源物联网 MQTT 消息服务器。

Erlang/OTP是出色的软实时 (Soft-Realtime)、低延时 (Low-Latency)、分布式 (Distributed)的语言平台。

MQTT 是轻量的 (Lightweight)、发布订阅模式 (PubSub) 的物联网消息协议。

EMQ X 设计目标是实现高可靠,并支持承载海量物联网终端的MQTT连接,支持在海量物联网设备间低延时消息路由:

  • 稳定承载大规模的 MQTT 客户端连接,单服务器节点支持50万到100万连接。
  • 分布式节点集群,快速低延时的消息路由,单集群支持1000万规模的路由。
  • 消息服务器内扩展,支持定制多种认证方式、高效存储消息到后端数据库。
  • 完整物联网协议支持,MQTT、MQTT-SN、CoAP、LwM2M、WebSocket 或私有协议支持。

2、启动emqx

官网连接:https://www.emqx.io/docs/zh/v5.1/deploy/install-docker.html#通过-docker-运行单个-emqx-节点
docker持久化:https://askemq.com/t/topic/2353
docker链接:https://hub.docker.com/r/emqx/emqx

复制代码
# docker run -d --name emqx emqx/emqx:4.0.0

3、复制emqx数据

复制代码
# mkdir -p mqtt/emqx && cd mqtt
# docker cp emqx:/opt/emqx/data emqx
# docker cp emqx:/opt/emqx/etc emqx
# docker cp emqx:/opt/emqx/lib emqx
# docker cp emqx:/opt/emqx/log emqx

4、授权emqx目录

复制代码
# chown -R 1000:1000 emqx/
# chmod -R 755  emqx/

5、配置docker-compose.yml

复制代码
# cat docker-compose.yml
version: '3'
services:
  mqtt:
    image: emqx/emqx:v4.0.0
    privileged: true
    restart: always
    container_name: mqtt
    hostname: mqtt
    environment:
      - TZ=Asia/Shanghai
      - EMQX_NODE_NAME=wielun@172.200.200.2
      - EMQX_HOST=172.200.200.2
      - EMQX_NAME=wielun
    ports:
      - 1883:1883 # MQTT/TCP 协议端口
      - 8081:8081 # HTTP
      - 8083:8083 # MQTT/WS 协议端口
      - 8883:8883 # MQTT/SSL 协议端口
      - 8084:8084 # MQTT/WSS 协议端口
      - 18083:18083 # MQTT/TCP 协议内部端口,仅用于本机客户端连接
    volumes:
      - /etc/localtime:/etc/localtime:ro
      - /usr/share/zoneinfo/:/usr/share/zoneinfo/:ro
      - ./emqx/data:/opt/emqx/data
      - ./emqx/etc:/opt/emqx/etc
      - ./emqx/lib:/opt/emqx/lib
      - ./emqx/log:/opt/emqx/log
    networks:
      default:
        ipv4_address: 172.200.200.2

networks:
  default:
    ipam:
      config:
      - subnet: 172.200.200.0/24

6、启动查看结果

复制代码
# docker-compose up -d
# ls emqx/data/mnesia/wielun@172.200.200.2/    # 数据存储,有对应的文件生成就正确

7、浏览器访问

http://IP:18083
默认账号密码:admin/public

相关推荐
小小管写大大码9 小时前
如何让vscode变得更智能?vscode接入claude实现自动编程
运维·ide·vscode·自动化·编辑器·ai编程·腾讯云ai代码助手
zhang1338308907510 小时前
CG-09H 超声波风速风向传感器 加热型 ABS材质 重量轻 没有机械部件
大数据·运维·网络·人工智能·自动化
Fᴏʀ ʏ꯭ᴏ꯭ᴜ꯭.11 小时前
Keepalived VIP迁移邮件告警配置指南
运维·服务器·笔记
物联网软硬件开发-轨物科技11 小时前
【轨物洞见】告别“被动维修”!预测性运维如何重塑老旧电站的资产价值?
运维·人工智能
程序员允诺11 小时前
[DevOps实战] 彻底解决依赖地狱:如何编译全静态、可移植的 Xorriso 工具
运维·devops
酣大智11 小时前
接口模式参数
运维·网络·网络协议·tcp/ip
一只自律的鸡11 小时前
【Linux驱动】bug处理 ens33找不到IP
linux·运维·bug
!chen12 小时前
linux服务器静默安装Oracle26ai
linux·运维·服务器
莫大33012 小时前
2核2G云服务器PHP8.5+MySQL9.0+Nginx(LNMP)安装WordPress网站详细教程
运维·服务器·nginx
刚刚入门的菜鸟12 小时前
php-curl
运维·web安全·php