
如果你使用 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 无法访问外链,可 打开说明文档 复制全文粘贴。文档会随站点更新,复制内容可能过期,建议定期检查。
emqtt-bench 是一个用 Erlang 编写的轻量级 MQTT v5.0 基准测试工具,用于评估 MQTT 服务器的性能。该工具支持模拟大量并发 MQTT 客户端,进行连接、订阅、发布等操作的性能测试,帮助用户评估 MQTT 服务器在不同场景下的处理能力,如最大并发连接数、消息吞吐量、延迟等关键指标。
注意:以下示例中,"Usage" 指的是镜像内的脚本
emqtt_bench,而 Docker 镜像名称为emqx/emqtt-bench。
%u、%c、%i),可生成动态主题用于测试 MQTT 服务器处理并发连接的能力。
命令选项
shdocker run -it emqx/emqtt-bench conn --help
选项说明:
| 选项 | 描述 | 默认值 |
|---|---|---|
| --help | 显示帮助信息 | - |
| -h, --host | MQTT 服务器主机名或 IP 地址 | localhost |
| -p, --port | MQTT 服务器端口 | 1883 |
| -c, --count | 最大客户端数量 | 200 |
| -n, --startnumber | 起始编号 | 0 |
| -i, --interval | 连接间隔(毫秒) | 10 |
| -u, --username | 连接用户名(可选) | - |
| -P, --password | 连接密码(可选) | - |
| -k, --keepalive | 保活时间(秒) | 300 |
| -C, --clean | 清除会话 | true |
| -S, --ssl | 使用 SSL 连接 | false |
| --certfile | 客户端证书文件路径(如需双向认证) | - |
| --keyfile | 客户端私钥文件路径(如需双向认证) | - |
| --ifaddr | 本地 IP 地址或接口地址 | - |
示例
以 100 个/秒的速率创建 50,000 个并发连接:
shdocker run -it emqx/emqtt-bench conn -c 50000 -i 10
用于测试 MQTT 服务器处理订阅操作的能力。
命令选项
shdocker run -it emqx/emqtt-bench sub --help
选项说明:
| 选项 | 描述 | 默认值 |
|---|---|---|
| --help | 显示帮助信息 | - |
| -h, --host | MQTT 服务器主机名或 IP 地址 | localhost |
| -p, --port | MQTT 服务器端口 | 1883 |
| -V, --version | MQTT 协议版本(3/4/5) | 5 |
| -c, --count | 最大客户端数量 | 200 |
| -n, --startnumber | 起始编号 | 0 |
| -i, --interval | 连接间隔(毫秒) | 10 |
| -t, --topic | 订阅主题(支持 %u、%c、%i 变量) | - |
| -q, --qos | 订阅 QoS 级别(0/1/2) | 0 |
| -u, --username | 连接用户名(可选) | - |
| -P, --password | 连接密码(可选) | - |
| -k, --keepalive | 保活时间(秒) | 300 |
| -C, --clean | 清除会话 | true |
| -S, --ssl | 使用 SSL 连接 | false |
| --certfile | 客户端证书文件路径(如需双向认证) | - |
| --keyfile | 客户端私钥文件路径(如需双向认证) | - |
| --ws | 使用 WebSocket 传输 | false |
| --ifaddr | 本地 IP 地址或接口地址 | - |
示例
以 100 个/秒的速率创建 50,000 个并发订阅客户端,订阅主题 bench/%i(%i 为客户端编号),QoS 级别 2:
shdocker run -it emqx/emqtt-bench sub -c 50000 -i 10 -t bench/%i -q 2
用于测试 MQTT 服务器处理消息发布的吞吐量和延迟。
命令选项
shdocker run -it emqx/emqtt-bench pub --help
选项说明:
| 选项 | 描述 | 默认值 |
|---|---|---|
| --help | 显示帮助信息 | - |
| -h, --host | MQTT 服务器主机名或 IP 地址 | localhost |
| -p, --port | MQTT 服务器端口 | 1883 |
| -V, --version | MQTT 协议版本(3/4/5) | 5 |
| -c, --count | 最大客户端数量 | 200 |
| -n, --startnumber | 起始编号 | 0 |
| -i, --interval | 连接间隔(毫秒) | 10 |
| -I, --interval_of_msg | 消息发送间隔(毫秒) | 1000 |
| -u, --username | 连接用户名(可选) | - |
| -P, --password | 连接密码(可选) | - |
| -t, --topic | 发布主题(支持 %u、%c、%i 变量) | - |
| -s, --size | 消息 payload 大小(字节) | 256 |
| -q, --qos | 发布 QoS 级别(0/1/2) | 0 |
| -r, --retain | 保留消息标志 | false |
| -k, --keepalive | 保活时间(秒) | 300 |
| -C, --clean | 清除会话 | true |
| -S, --ssl | 使用 SSL 连接 | false |
| --certfile | 客户端证书文件路径(如需双向认证) | - |
| --keyfile | 客户端私钥文件路径(如需双向认证) | - |
| --ws | 使用 WebSocket 传输 | false |
| --ifaddr | 本地 IP 地址或接口地址 | - |
示例
创建 100 个并发客户端,每个客户端以 100 条/秒的速率发布消息,主题 bench/%i(%i 为客户端编号),消息大小 256 字节:
shdocker run -it emqx/emqtt-bench pub -c 100 -I 10 -t bench/%i -s 256
通过 --ifaddr 选项指定客户端使用的本地 IP 地址:
shdocker run -it emqx/emqtt-bench pub --ifaddr 192.168.1.10 docker run -it emqx/emqtt-bench sub --ifaddr 192.168.2.10
连接使用 SSL/TLS 加密的 MQTT 服务器(端口通常为 8883):
sh# 订阅测试 docker run -it emqx/emqtt-bench sub -c 100 -i 10 -t bench/%i -p 8883 -S # 发布测试 docker run -it emqx/emqtt-bench pub -c 100 -I 10 -t bench/%i -p 8883 -s 256 -S
使用客户端证书和私钥进行双向 SSL 认证:
sh# 订阅测试(需挂载证书文件到容器内,假设本地证书路径为 /local/certs/) docker run -it -v /local/certs:/certs emqx/emqtt-bench sub -c 100 -i 10 -t bench/%i -p 8883 --certfile /certs/client-cert.pem --keyfile /certs/client-key.pem # 发布测试 docker run -it -v /local/certs:/certs emqx/emqtt-bench pub -c 100 -i 10 -t bench/%i -s 256 -p 8883 --certfile /certs/client-cert.pem --keyfile /certs/client-key.pem
注意:双向 SSL 连接需将本地证书文件挂载到容器内,使用
-v参数指定挂载路径。
-c(客户端数量)选项不应设置超过 60,000。EMQX 团队
您可以使用以下命令拉取该镜像。请将 <标签> 替换为具体的标签版本。如需查看所有可用标签版本,请访问 标签列表页面。
来自真实用户的反馈,见证轩辕镜像的优质服务