轩辕镜像 官方专业版
轩辕镜像
专业版
轩辕镜像 官方专业版
轩辕镜像
专业版
首页个人中心搜索镜像
交易
充值流量¥7起我的订单
文档
工具
提交工单页面收录
vernemq

aerialtech/vernemq

aerialtech

这是一个高性能分布式MQTT消息broker镜像,支持水平与垂直扩展,能处理大量并发连接,保持低延迟和容错性,是IoT平台或智能产品的可靠消息枢纽。

下载次数: 0状态:社区镜像维护者:aerialtech仓库类型:镜像最近更新:6 年前
让 AI 帮你使用轩辕镜像? · 展开查看说明 · 点击收起说明

如果你使用 DeepSeek、元宝 AI、Copilot、ChatGPT 等 AI 工具,协助配置轩辕镜像、编写 docker pull 命令、修改 Docker Compose 镜像地址、配置镜像加速、排查镜像拉取失败、分析报错日志等问题,请先让 AI 阅读并遵守轩辕镜像的规则文档。

只需在 AI 对话中先发送下面这句话即可:

请先完整阅读并严格遵守以下文档中的全部规则与要求:

https://xuanyuan.cloud/agents.md

在未充分阅读并理解该文档前,不要生成任何命令、配置、修改建议、故障排查方案或技术回答。后续所有输出都必须严格以该文档中的规范为最高优先级执行。

查看 agents.md 用法指南与完整示范。国内用户首推 元宝 AI、DeepSeek 的深度思考模式,不推荐豆包 AI;Cursor 等编辑器可在对话 @ 该链接,或加入 User Rules。 若 AI 无法访问外链,可 打开说明文档 复制全文粘贴。文档会随站点更新,复制内容可能过期,建议定期检查。

中文简介
下载命令
镜像标签列表与下载命令
轩辕镜像,让镜像更快,让人生更轻。
点击查看

docker-vernemq

VerneMQ是什么?

VerneMQ是一款高性能的分布式MQTT消息broker。它可在普通硬件上进行水平和垂直扩展,以支持大量并发发布者和消费者,同时保持低延迟和容错能力。VerneMQ是IoT平台或智能产品的可靠消息枢纽。

VerneMQ是采用Erlang开发的Apache2许可分布式MQTT broker。

如何使用该镜像

1. 使用Helm在Kubernetes上部署

首先根据文档安装并配置Helm。然后添加VerneMQ Helm图表仓库:

bash
helm repo add vernemq https://vernemq.github.io/docker-vernemq

现在可以在Kubernetes集群上部署VerneMQ:

bash
helm install vernemq/vernemq

更多信息请查看Helm图表的README。

2. 使用纯Docker命令

bash
docker run --name vernemq1 -d erlio/docker-vernemq

有时需要配置端口转发(例如在Mac上):

bash
docker run -p 1883:1883 --name vernemq1 -d erlio/docker-vernemq

这会启动一个新节点,监听1883端口(MQTT连接)和8080端口(MQTT over WebSocket连接)。但此时broker无法认证连接的客户端。要允许***客户端,使用DOCKER_VERNEMQ_ALLOW_ANONYMOUS=on环境变量:

bash
docker run -e "DOCKER_VERNEMQ_ALLOW_ANONYMOUS=on" --name vernemq1 -d erlio/docker-vernemq

自动加入VerneMQ集群

这允许新启动的容器自动加入VerneMQ集群。假设你已像上面的示例启动了第一个节点,可以按以下方式自动加入集群(当前集群仅包含单个容器'vernemq1'):

bash
docker run -e "DOCKER_VERNEMQ_DISCOVERY_NODE=<VERNEMQ1的IP>" --name vernemq2 -d erlio/docker-vernemq

(注意:可以使用docker inspect <容器名/ID> | grep \"IPAddress\"查找Docker容器的IP。)

3. 在Kubernetes上不使用Helm的自动集群

在Kubernetes中运行VerneMQ时,可以让匹配特定标签的pod自动组成集群。此功能使用Kubernetes API发现其他节点,依赖默认pod服务账户(需启用)。

只需在pod的环境中设置DOCKER_VERNEMQ_DISCOVERY_KUBERNETES=1,并通过MY_POD_NAME暴露自己的pod名称。默认情况下,此设置会让同一命名空间中带有app=vernemq标签的所有pod加入同一集群。集群名称(默认cluster.local)、命名空间和标签设置可分别通过DOCKER_VERNEMQ_KUBERNETES_CLUSTER_NAME、DOCKER_VERNEMQ_KUBERNETES_NAMESPACE和DOCKER_VERNEMQ_KUBERNETES_LABEL_SELECTOR覆盖。

pod环境的示例配置如下:

yaml
env:
  - name: DOCKER_VERNEMQ_DISCOVERY_KUBERNETES
    value: "1"
  - name: MY_POD_NAME
    valueFrom:
      fieldRef:
        fieldPath: metadata.name
  - name: DOCKER_VERNEMQ_KUBERNETES_LABEL_SELECTOR
    value: "app=vernemq,release=myinstance"

启用Kubernetes自动集群时,不要设置DOCKER_VERNEMQ_DISCOVERY_NODE。

若遇到如下"SSL证书错误(主题名称与主机名不匹配)",可尝试设置DOCKER_VERNEMQ_KUBERNETES_INSECURE为"1":

text
kubectl logs vernemq-0
  % Total    % Received % Xferd  Average Speed   Time    Time     Time  Current
                                 Dload  Upload   Total   Spent    Left  Speed
  0     0    0     0    0     0      0      0 --:--:-- --:--:-- --:--:--     0curl: (51) SSL: certificate subject name 'client' does not match target host name 'kubernetes.default.svc.cluster.local'
  % Total    % Received % Xferd  Average Speed   Time    Time     Time  Current
                                 Dload  Upload   Total   Spent    Left  Speed
  0     0    0     0    0     0      0      0 --:--:-- --:--:-- --:--:--     0curl: (51) SSL: certificate subject name 'client' does not match target host name 'kubernetes.default.svc.cluster.local'
vernemq failed to start within 15 seconds,
see the output of 'vernemq console' for more information.
If you want to wait longer, set the environment variable
WAIT_FOR_ERLANG to the number of seconds to wait.
...

如果使用vernemq.conf.local文件,可在配置中插入占位符###IPADDRESS###,在POD创建时会替换为VerneMQ运行的POD实际IP地址,使VMQ集群成为可能。

4. 使用Docker Swarm

请遵循官方Docker指南正确设置包含一个或多个节点的Swarm集群。

Swarm设置完成后,可部署VerneMQ栈。以下代码片段使用docker-compose.yml文件描述栈:

yaml
version: "3.7"
services:
  vmq0:
    image: erlio/docker-vernemq
    environment:
      DOCKER_VERNEMQ_SWARM: 1
  vmq:
    image: erlio/docker-vernemq
    depends_on:
      - vmq0
    environment:
      DOCKER_VERNEMQ_SWARM: 1
      DOCKER_VERNEMQ_DISCOVERY_NODE: vmq0
    deploy:
      replicas: 2

运行docker stack deploy -c docker-compose.yml my-vernemq-stack部署3节点VerneMQ集群。

注意:Docker Swarm目前缺乏类似Kubernetes中statefulset的功能。因此VerneMQ必须依赖特定的发现服务(如上的vmq0服务),该服务需在其他副本之前启动。

检查集群状态

要检查上述容器是否成功集群,可执行vmq-admin命令:

bash
docker exec vernemq1 vmq-admin cluster show
+--------------------+-------+
|        Node        |Running|
+--------------------+-------+
|VerneMQ@172.17.0.151| true  |
|VerneMQ@172.17.0.152| true  |
+--------------------+-------+

若在Kubernetes中使用DOCKER_VERNEMQ_DISCOVERY_KUBERNETES=1启动VerneMQ集群,可通过kubectl执行vmq-admin:

bash
kubectl exec vernemq-0 -- vmq-admin cluster show
+---------------------------------------------------+-------+
|                       Node                        |Running|
+---------------------------------------------------+-------+
|VerneMQ@vernemq-0.vernemq.default.svc.cluster.local| true  |
|VerneMQ@vernemq-1.vernemq.default.svc.cluster.local| true  |
+---------------------------------------------------+-------+

所有vmq-admin命令均可用。更多信息请查看[***]

在Consul + Nomad上自动集群

在Nomad中运行VerneMQ时,可利用Nomad填充的Consul服务目录,使VerneMQ容器自动组成集群。

在Job环境中设置DOCKER_VERNEMQ_DISCOVERY_CONSUL=1。确保epmd端口(4369)注册到特定服务,并将此服务名称设置到DOCKER_VERNEMQ_DISCOVERY_CONSUL_SERVICE_NAME环境变量中,且定义了健康检查(以便仅当VerneMQ容器实际监听此端口时才注册)。

以下是Nomad job中运行该容器的重要代码片段(此job不完整,仅展示自动发现设置):

hcl
job "vernemq" {
  type = "service"

  group "mqtt" {
    task "mqtt" {
      driver = "docker"
      config {
        # 由于自动发现、名称和IP,我们使用主机网络
        # (获得与Kubernetes中clusterIP类似的路由)
        network_mode = "host"

        port_map {
          epmd                = 4369
        }
      }

      env {
        "DOCKER_IP_ADDRESS"                  = "${attr.unique.network.ip-address}"
        "DOCKER_VERNEMQ_NODENAME"            = "VerneMQ@${attr.unique.network.ip-address}"

        # VerneMQ集群(Consul+Nomad)
        "DOCKER_VERNEMQ_DISCOVERY_CONSUL"              = "1"
        "DOCKER_VERNEMQ_DISCOVERY_CONSUL_HOST"         = "${attr.unique.network.ip-address}"
        "DOCKER_VERNEMQ_DISCOVERY_CONSUL_SERVICE_NAME" = "mqtt-discovery"
        "DOCKER_VERNEMQ_DISCOVERY_CONSUL_STAGGER_IND"  = "${NOMAD_ALLOC_INDEX}"
      }

      resources {
        network {
          port "epmd" {
            static = 4369
          }
        }
      }

      service {
        # 此服务仅用于暴露其中一个MQTT broker的动态地址
        # 方便其他broker加入
        name = "mqtt-discovery"
        port = "epmd"

        check {
          type     = "tcp"
          port     = "epmd"
          interval = "10s"
          timeout  = "2s"
          initial_status = "critical"
        }
      }
    }
  }
}

自动发现的其他有用环境变量:

  • DOCKER_VERNEMQ_DISCOVERY_CONSUL_HOST:用于向Consul服务目录发起API调用的主机
  • DOCKER_VERNEMQ_DISCOVERY_CONSUL_PORT:允许自定义Consul API端口,默认向8500端口发送请求
  • DOCKER_VERNEMQ_DISCOVERY_CONSUL_STAGGER_IND:用于在不同分配之间添加时间偏移:第二个分配等待一点时间确保第一个分配准备好接收加入节点,然后n+1节点比n节点等待更长时间,依此类推。

已知限制:

  • 尚未处理Consul TLS和ACL
  • 主机网络并非理想选择,计划后续改进

VerneMQ配置

vernemq.conf中所有可用的配置参数均可使用DOCKER_VERNEMQ前缀加上配置参数名来定义。例如:allow_anonymous=on对应-e "DOCKER_VERNEMQ_ALLOW_ANONYMOUS=on",allow_register_during_netsplit=on对应-e "DOCKER_VERNEMQ_ALLOW_REGISTER_DURING_NETSPLIT=on"。所有可用配置参数可在[***]

日志

VerneMQ将崩溃和错误日志文件存储在/var/log/vernemq/,默认不将控制台日志写入磁盘以避免填满容器磁盘空间。但可通过设置环境变量DOCKER_VERNEMQ_LOG__CONSOLE为both来改变此行为,这会让VerneMQ将日志发送到stdout和/var/log/vernemq/console.log。更多信息请查看VerneMQ日志文档:[***]

备注

部分配置变量包含点.。例如,若要调整VerneMQ的日志级别,需使用-e "DOCKER_VERNEMQ_LOG.CONSOLE.LEVEL=debug"。但某些容器平台(如Kubernetes)不支持环境变量中的点和其他特殊字符。若在这类平台上,可将点替换为双下划线__。上述示例将变为-e "DOCKER_VERNEMQ_LOG__CONSOLE__LEVEL=debug"。

对于包含点的配置名称,存在一些例外情况。以下是示例:

vernemq.conf中的格式环境变量名称中的格式
vmq_webhooks.pool_timeout = 60000DOCKER_VERNEMQ_VMQ_WEBHOOKS__POOL_timeout=6000
vmq_webhooks.pool_timeout = 60000DOCKER_VERNEMQ_VMQ_WEBHOOKS.pool_timeout=60000

文件基于认证

可通过添加用户和密码作为环境变量来设置文件基于认证:

DOCKER_VERNEMQ_USER_<用户名>='密码'

其中<用户名>是你要使用的用户名。可多次执行此操作以创建所需用户。用户名始终会转换为小写。

注意 - 密码中不能包含=字符。

镜像拉取方式

您可以使用以下命令拉取该镜像。请将 <标签> 替换为具体的标签版本。如需查看所有可用标签版本,请访问 标签列表页面。

轩辕镜像加速拉取命令点我查看更多 vernemq 镜像标签

docker pull docker.xuanyuan.run/aerialtech/vernemq:<标签>

使用方法:

  • 登录认证方式
  • 免认证方式

DockerHub 原生拉取命令

docker pull aerialtech/vernemq:<标签>

轩辕镜像配置手册

按平台快速找到配置文档

Docker

登录仓库拉取

登录认证 · 私有仓库

专属域名拉取

免登录 · 高速拉取

Linux

Docker 镜像配置

Windows / Mac

Docker Desktop 配置

MacOS OrbStack

OrbStack 容器

Docker Compose

Compose 项目配置

NAS

群晖

Synology 配置

飞牛

fnOS 镜像配置

绿联

绿联 NAS

威联通

QNAP 配置

极空间

极空间 NAS

企业仓库

其他仓库

ghcr · Quay · nvcr

Harbor 镜像源

Proxy Repository 对接

Portainer 镜像源

Registries 配置

Nexus 镜像源

Docker Proxy 缓存

开发工具

Dev Containers

VS Code 开发容器

Podman

Podman 配置指南

Singularity / Apptainer

HPC 科学计算容器

Kubernetes

K8s Containerd

Kubernetes · Containerd

K3s

轻量级集群

面板 / 网络

爱快路由

iKuai 镜像加速

宝塔面板

一键配置镜像源

AI

用 AI 使用轩辕镜像

agents.md · AI 对话 · 提示词

一键安装

一键安装 Docker

Linux Docker 一键安装

需要其他帮助?请查看我们的 常见问题Docker 镜像访问常见问题解答 或 提交工单

镜像拉取常见问题

功能

免费版与专业版区别

功能对比 · 版本选择

支持的镜像仓库

Docker Hub · GCR · GHCR

新手拉取配置

登录 · 专属域名 · 配置

docker search 限制

专属域名 · Hub 搜索

不支持 push

仅支持 pull · 不支持

拉取速度原因

带宽 · 缓存 · 冷热镜像

错误码

402 与流量用尽

402 · 流量包 · 充值

401 认证失败

401 · docker login

manifest unknown

标签错误 · 镜像不存在

410 Gone 排查

410 · Docker 升级

429 限流

免费版 · 请求频率

其他报错

DNS 超时

DNS 解析 · 网络超时

TLS 证书失败

no matching manifest(架构)

账号

失败是否计费

manifest · blob · 计费

申请开发票(企业 / 个人)

企业 · 个人 · 工单

修改登录密码

网站 · 仓库 · 重置

注销账户

工单 · 数据 · 注销

原理

mirrors 不生效

daemon.json · 重启

去掉域名前缀

docker tag · 重命名

指定架构拉取

ARM64 · AMD64 · 多架构

latest 与「最新」

digest · 版本号 · 标签

查看全部问题→

用户好评

来自真实用户的反馈,见证轩辕镜像的优质服务

用户头像

oldzhang

运维工程师

Linux服务器

5

"Docker访问体验非常流畅,大镜像也能快速完成下载。"

轩辕镜像
镜像详情
...
aerialtech/vernemq
教程轩辕镜像功能与使用教程
定价查看流量套餐与价格
热门查看热门 Docker 镜像推荐
博客Docker 镜像公告与技术博客
专业版 · 高速稳定拉取镜像
高速镜像下载·在线技术支持·99.95% SLA 保障·付费会员免广告
50GB 仅 ¥7/年
专业版 · 高速稳定拉取镜像
50GB 仅 ¥7/年
高速镜像下载·在线技术支持·99.95% SLA 保障·付费会员免广告
商务合作:点击复制邮箱
用户协议·隐私政策·©2024-2026 源码跳动
用户协议·隐私政策©2024-2026 杭州源码跳动科技有限公司商务合作:点击复制邮箱

更多 vernemq 镜像推荐

vernemq/vernemq logo

vernemq/vernemq

vernemq
官方VerneMQ Docker镜像仓库,提供高性能MQTT消息代理,用于物联网设备间的消息传递与通信。
25 次收藏500万+ 次下载
1 个月前更新
vernemq/vmq-operator logo

vernemq/vmq-operator

vernemq
VerneMQ Kubernetes Operator
10万+ 次下载
2 年前更新
vernemq/vmq-plugin-bundler logo

vernemq/vmq-plugin-bundler

vernemq
该镜像用于构建与指定VerneMQ版本依赖一致的插件,将插件打包为archive并通过HTTP服务提供,简化Docker化VerneMQ环境中自定义插件的使用,仅支持rebar3构建的插件。
1 次收藏10万+ 次下载
6 年前更新
astarte/vernemq logo

astarte/vernemq

astarte
为Astarte定制的VerneMQ版本
10万+ 次下载
1 个月前更新
mainflux/vernemq logo

mainflux/vernemq

mainflux
Mainflux custom package of VerneMQ broker.
1 次收藏5万+ 次下载
4 年前更新
pasientskyhosting/vernemq logo

pasientskyhosting/vernemq

pasientskyhosting
暂无描述
1万+ 次下载
4 年前更新

查看更多 vernemq 相关镜像