- 拉取emqx镜像
docker pull emqx/emqx:v3.0.1
- 启动emqx,
docker run -d --name emqx -p 1883:1883 -p 8083:8083 -p 8883:8883 -p 8084:8084 -p 18083:18083 emqx/emqx:v3.0.1
- 修改需要账号密码登录,认证方式为mysql。
1、进入emqx的docker容器内:docker exec -it emqx /bin/sh
2、修改etc目录中的exqx.conf文件中的allow_anonymous = true
为allow_anonymous = false
(普通模式下使用/allow_搜索),修改后保存退出。
3、进入pluigns目录中,修改emqx_auth_mysql.conf文件:
修改完成后,保存退出。
4. 在mysql中创建与上面mqtt数据库名称一致的数据库
5. 插入表,然后在表中的username输入emqx,password
输入efa1f375d76194fa51a3556a97e641e61685f914d446979da50a551a4333ffd7即默认sha256加密后的,明文为public,保存。
CREATE TABLE `mqtt_user` (
`id` int(11) unsigned NOT NULL AUTO_INCREMENT,
`username` varchar(100) DEFAULT NULL,
`password` varchar(100) DEFAULT NULL,
`salt` varchar(35) DEFAULT NULL,
`is_superuser` tinyint(1) DEFAULT 0,
`created` datetime DEFAULT NULL,
PRIMARY KEY (`id`),
UNIQUE KEY `mqtt_username` (`username`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;
- 重启。docker restart 容器ID
- 开启mysql认证
- 在线测试网址:
http://tools.emqx.io/recent_connections/daf56bf9-e56d-467d-bd32-3c8096d76569
测试成功。