EMQX 开启 **MySQL + password_based** 认证

我给你最简单、一步到位、直接能用 的 EMQX + MySQL 密码认证 插入用户SQL,你复制执行就能让大疆机场连接 MQTT。

一、先说结论

EMQX 开启 MySQL + password_based 认证后,往 MySQL 里插入用户只需要一条 INSERT

关键只有 3 个字段:

  • username
  • password
  • salt(留空即可)
  • is_superuser(0 就行)

二、你只需要执行这条 SQL(直接复制)

sql 复制代码
INSERT INTO mqtt_user (username, password, salt, is_superuser)
VALUES ('你的MQTT用户名', '你的MQTT密码', '', 0);

真实可测试例子(大疆机场直接能用)

sql 复制代码
INSERT INTO mqtt_user (username, password, salt, is_superuser)
VALUES ('dock_user_001', 'X9B27sK4pR5zQ3vG7tN1dF8hJ0k001', '', 0);

执行完 → 大疆机场立刻就能用这个账号密码连接 EMQX


三、必须确认 EMQX 配置(和我这个一致才有效)

打开 EMQX 的认证配置:
etc/plugins/emqx_auth_mysql.conf

确保这 3 项配置 和我一样

复制代码
auth.mysql.password_hash = plain
auth.mysql.auth_query = select password from mqtt_user where username = '%u' limit 1
auth.mysql.password_based = on
  • password_hash = plain → 密码明文存储
  • auth_query → 查密码
  • password_based = on → 开启密码认证

这样你直接插入明文密码就能用,最适合大疆机场对接。


四、如果你想批量生成用户(直接运行)

sql 复制代码
-- 生成10个大疆机场可用的MQTT账号
INSERT INTO mqtt_user (username, password, salt, is_superuser)
VALUES
('dock_001', 'pwd_001ABC', '', 0),
('dock_002', 'pwd_002ABC', '', 0),
('dock_003', 'pwd_003ABC', '', 0);

五、验证是否生效

  1. 重启 EMQX 插件
bash 复制代码
emqx_ctl plugins reload emqx_auth_mysql
  1. 用MQTT工具测试连接
  • 地址:你的IP
  • 端口:1883
  • 用户名:dock_user_001
  • 密码:X9B27sK4pR5zQ3vG7tN1dF8hJ0k001

能连上 = 成功


六、超级精简总结

EMQX MySQL 密码认证 =
往 mqtt_user 表插入 username + password 明文即可

不需要加密

不需要salt

不需要复杂配置


相关推荐
程序猿阿伟20 分钟前
《一套完整方法论:搞定图形应用的Docker镜像优化》
数据库·docker·容器
二等饼干~za89866829 分钟前
geo优化源码开发搭建技术分享
大数据·网络·数据库·人工智能·音视频
数据库小学妹1 小时前
HTAP混合负载架构:如何用一个数据库同时搞定交易和分析
数据库·经验分享·架构·dba
wuxinyan1231 小时前
工业级大模型学习之路029:解决双智能体调用数据库报错问题
数据库·人工智能·python·学习·智能体
Elastic 中国社区官方博客1 小时前
Elastic 线下 Meetup 将于 2026 年 7 月 26 号下午在深圳举行
大数据·数据库·人工智能·elasticsearch·搜索引擎·ai·全文检索
YL200404261 小时前
【Redis实战篇】秒杀实现方案(以优惠券秒杀为例)
数据库·redis
搜狐技术产品小编20231 小时前
破局与重构:纯端侧 Android 自动化引擎的尝试与未来推演
android·运维·重构·自动化
DIY源码阁1 小时前
JavaSwing宿舍管理系统 - MySQL版
java·数据库·mysql·eclipse
cfm_29141 小时前
MySQL8.0 InnoDB Cluster
数据库·mysql