1. 拉取emqx镜像docker pull emqx/emqx:v3.0.1
  2. 启动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
  3. 修改需要账号密码登录,认证方式为mysql。
    1、进入emqx的docker容器内:docker exec -it emqx /bin/sh
    2、修改etc目录中的exqx.conf文件中的allow_anonymous = trueallow_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;

  1. 重启。docker restart 容器ID
  2. 开启mysql认证
    在这里插入图片描述
  3. 在线测试网址:http://tools.emqx.io/recent_connections/daf56bf9-e56d-467d-bd32-3c8096d76569
    测试成功。
    在这里插入图片描述
Logo

华为开发者空间,是为全球开发者打造的专属开发空间,汇聚了华为优质开发资源及工具,致力于让每一位开发者拥有一台云主机,基于华为根生态开发、创新。

更多推荐