日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

emqx配置mysql认证,emqx使用mysql完成用户密码验证和ACL鉴权

發布時間:2024/9/27 数据库 27 豆豆
生活随笔 收集整理的這篇文章主要介紹了 emqx配置mysql认证,emqx使用mysql完成用户密码验证和ACL鉴权 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

emqx使用mysql完成用戶密碼驗證和ACL鑒權

emqx使用mysql完成用戶密碼驗證和ACL鑒權

摘要:前幾篇博客介紹的是使用配置文件配置了ACL和客戶端用戶名密碼配置實現生產環境下的安全登錄和權限控制,各項配置比較繁瑣,修改起來比較麻煩,下面介紹使用mysql進行統一的管理控制。

環境說明:

1.linux系統下,centos 7環境

2.使用docker運行emqtt服務器,參照:https://blog.csdn.net/u011089760/article/details/89892591

3.進入docker方式,參照:https://blog.csdn.net/u011089760/article/details/89892591

4.MySQL版本:5.6+

1)配置mysql連接配置

加載mysql權限插件

如果無法加載,可以通過界面配置的方式進行插件的配置和啟動

mysql數據庫建表

CREATE TABLE `mqtt_acl` (

`id` int(11) unsigned NOT NULL AUTO_INCREMENT,

`allow` int(1) DEFAULT NULL COMMENT '0: deny, 1: allow',

`ipaddr` varchar(60) DEFAULT NULL COMMENT 'IpAddress',

`username` varchar(100) DEFAULT NULL COMMENT 'Username',

`clientid` varchar(100) DEFAULT NULL COMMENT 'ClientId',

`access` int(2) NOT NULL COMMENT '1: subscribe, 2: publish, 3: pubsub',

`topic` varchar(100) NOT NULL DEFAULT '' COMMENT 'Topic Filter',

PRIMARY KEY (`id`)

) ENGINE=InnoDB DEFAULT CHARSET=utf8;

CREATE TABLE `mqtt_user`

( `id` int(11) unsigned NOT NULL AUTO_INCREMENT,

`username` varchar(100) DEFAULT NULL,

`password` varchar(100) DEFAULT NULL,

`salt` varchar(20) DEFAULT NULL,

`is_superuser` tinyint(1) DEFAULT 0,

`created` datetime DEFAULT NULL, PRIMARY KEY (`id`), UNIQUE KEY `mqtt_username` (`username`) ) ENGINE=MyISAM DEFAULT CHARSET=utf8;

插入ACL鑒權及用戶登錄賬號密碼數據數據

INSERT INTO `mqtt_acl` (`id`, `allow`, `ipaddr`, `username`, `clientid`, `access`, `topic`)

VALUES (1,1,NULL,'$all',NULL,2,'#'),

(2,0,NULL,'$all',NULL,1,'$SYS/#'),

(3,0,NULL,'$all',NULL,1,'eq #'),

(5,1,'127.0.0.1',NULL,NULL,2,'$SYS/#'),

(6,1,'127.0.0.1',NULL,NULL,2,'#'),

(7,1,NULL,'dashboard',NULL,1,'$SYS/#');

如果is_superuser是1的話,acl中的控制將不受限制

如配置遇到問題或其他技術相關,可以留言

emqx使用mysql完成用戶密碼驗證和ACL鑒權相關教程

總結

以上是生活随笔為你收集整理的emqx配置mysql认证,emqx使用mysql完成用户密码验证和ACL鉴权的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。