专属
文档
插件
助手
邀请
顶部
快速返回页面顶部
收起
收起工具栏
轩辕镜像 官方专业版
轩辕镜像
专业版
轩辕镜像 官方专业版
轩辕镜像
专业版
首页个人中心搜索镜像

交易
充值流量我的订单

文档

工具

功能
提交工单页面收录

帮助
轩辕镜像免费版

其他
关于我们网站地图
热门搜索:
technocore-vernemq

scififarms/technocore-vernemq

自动构建
scififarms

为TechnoCore提供MQTT消息代理功能,基于高性能分布式VerneMQ,支持水平/垂直扩展、高并发连接与集群部署,适用于IoT平台及智能产品的可靠消息中枢。

下载次数: 0状态:自动构建维护者:scififarms仓库类型:镜像最近更新:4 年前
让 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消息代理。它可在通用硬件上进行水平和垂直扩展,以支持大量并发发布者和消费者,同时保持低延迟和容错能力。VerneMQ是IoT平台或智能产品的可靠消息中枢。

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

如何使用此镜像

1. 接受VerneMQ最终用户许可协议(EULA)

注意: 使用官方Docker镜像前,您必须接受VerneMQ最终用户许可协议。您可以通过此处了解如何接受该协议。

2. 使用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。

3. 使用纯Docker命令

bash
docker run -e "DOCKER_VERNEMQ_ACCEPT_EULA=yes" --name vernemq1 -d vernemq/vernemq

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

bash
docker run -p 1883:1883 -e "DOCKER_VERNEMQ_ACCEPT_EULA=yes" --name vernemq1 -d vernemq/vernemq

这将启动一个新节点,在1883端口监听MQTT连接,在8080端口监听WebSocket上的MQTT连接。但此时代理无法对连接的客户端进行身份验证。要允许***客户端,请使用DOCKER_VERNEMQ_ALLOW_ANONYMOUS=on环境变量:

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

自动加入VerneMQ集群

这允许新启动的容器自动加入VerneMQ集群。假设您已按上述示例启动第一个节点,您可以按以下方式自动加入集群(当前由单个容器'vernemq1'组成):

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

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

4. 在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集群成为可能。

5. 使用Docker Swarm

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

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

yaml
version: "3.7"
services:
  vmq0:
    image: vernemq/vernemq
    environment:
      DOCKER_VERNEMQ_SWARM: 1
  vmq:
    image: vernemq/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命令均可用。更多信息请参见[***]

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_<USERNAME>='password'

其中<USERNAME>是您要使用的用户名。可以根据需要多次执行此操作以创建所需用户。用户名将始终以小写创建。

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

镜像拉取方式

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

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

docker pull docker.xuanyuan.run/scififarms/technocore-vernemq:<标签>

使用方法:

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

DockerHub 原生拉取命令

docker pull scififarms/technocore-vernemq:<标签>

更多 technocore-vernemq 镜像推荐

vernemq/vernemq logo

vernemq/vernemq

vernemq
官方VerneMQ Docker镜像仓库,提供高性能MQTT消息代理,用于物联网设备间的消息传递与通信。
25 次收藏500万+ 次下载
24 天前更新
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 年前更新
erlio/docker-vernemq logo

erlio/docker-vernemq

erlio
这是高性能分布式MQTT消息代理VerneMQ的Docker镜像,支持水平/垂直扩展与低延迟容错,是IoT平台或智能产品的可靠消息枢纽。
23 次收藏500万+ 次下载
6 年前更新
astarte/vernemq logo

astarte/vernemq

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

scififarms/technocore

scififarms
TechnoCore是一个用于部署Docker服务的脚本/容器,旨在简化Docker服务的部署流程,支持Home Assistant、ESPHome、Grafana等多种服务的快速部署与管理。
10万+ 次下载
4 年前更新

查看更多 technocore-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访问体验非常流畅,大镜像也能快速完成下载。"

轩辕镜像
镜像详情
...
scififarms/technocore-vernemq
教程轩辕镜像功能与使用教程
价格查看流量套餐与价格
热门查看热门 Docker 镜像推荐
博客Docker 镜像公告与技术博客
官方公众号:源码跳动|官方技术交流群:51517718
官方公众号:源码跳动|官方技术交流群:|问题咨询请:提交工单
商务合作:点击复制邮箱
©2024-2026 源码跳动
商务合作:点击复制邮箱Copyright © 2024-2026 杭州源码跳动科技有限公司. All rights reserved.