EMQ-百万级分布式开源物联网MQTT消息服务器。

MQTT 认证设置

EMQ 消息服务器认证由一系列认证插件(Plugin)提供,系统支持按用户名密码、ClientID 或匿名认证。

系统默认开启匿名认证(anonymous),通过加载认证插件可开启的多个认证模块组成认证链:

---------------- ---------------- ------------

Client --> | Username认证 | -ignore-> | ClientID认证 | -ignore-> | 匿名认证 |

---------------- ---------------- ------------

| | |

\|/ \|/ \|/

allow | deny allow | deny allow | deny

注解

EMQ 2.0 消息服务器还提供了 MySQL、PostgreSQL、Redis、MongoDB、HTTP、LDAP 认证插件。

1. 首先,当然是禁用匿名认证了,不然你的mqtt服务器任何都可以连接,岂不是很危险。

进入emqttd安装目录的etc

修改etc目录下的emq.conf文件, vim emq.conf 找到 mqtt.all_anonymous配置项将其置为false

2. Mysql插件认证

通过 MySQL 数据库表认证,可创建如下的 ‘mqtt_user’ 表:

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;

etc/plugins/emq_auth_mysql.conf 配置 ‘super_query’, ‘auth_query’, ‘password_hash’:

## Mysql Server 数据库的ip:port

auth.mysql.server = 127.0.0.1:3306

## Mysql Pool Size 池大小

auth.mysql.pool = 8

## Mysql Username 用户名(根据实际情况填写,别问为什么是xxx)

auth.mysql.username = xxx

## Mysql Password 密码

auth.mysql.password = xxx

## Mysql Database 数据库实例的名字

auth.mysql.database = mqtt

## Variables: %u = username, %c = clientid

## Authentication Query: select password only

auth.mysql.auth_query = select password from mqtt_user where username = '%u' limit 1

## Password hash: plain, md5, sha, sha256, pbkdf2

## 密码加密方式 sha256,md5等 也可以加盐 salt,这个稍后细细道来

auth.mysql.password_hash = sha256

## %% Superuser Query

auth.mysql.super_query = select is_superuser from mqtt_user where username = '%u' limit 1

以上配置项的值根据自身填写。

需要注意,当你的密码是通过md5+salt加密的时候,需要修改2个配置项

## Authentication Query: select password only

## sql语句同时也需将salt查出来,肯定 你事先肯定要存入表中。

auth.mysql.auth_query = select password,salt from mqtt_user where username = '%u' limit 1

## 加密方式为 md5 + salt 盐在密码后

auth.mysql.password_hash = md5,salt

ok,这样mysql插件 认证搞定。

访问控制(ACL)

MQ 消息服务器通过 ACL(Access Control List) 实现 MQTT 客户端访问控制。

ACL 访问控制规则定义:

允许(Allow)|拒绝(Deny) 谁(Who) 订阅(Subscribe)|发布(Publish) 主题列表(Topics)

MQTT 客户端发起订阅/发布请求时,EMQ 消息服务器的访问控制模块,会逐条匹配 ACL 规则,直到匹配成功为止:

--------- --------- ---------

Client -> | Rule1 | --nomatch--> | Rule2 | --nomatch--> | Rule3 | --> Default

--------- --------- ---------

| | |

match match match

\|/ \|/ \|/

allow | deny allow | deny allow | deny

默认访问控制设置

EMQ 消息服务器默认访问控制,在 etc/emq.conf 中设置:

## ACL nomatch

mqtt.acl_nomatch = allow

## Default ACL File

mqtt.acl_file = etc/acl.conf

ACL 规则定义在 etc/acl.conf,EMQ 启动时加载到内存:

%% Allow 'dashboard' to subscribe '$SYS/#'

{allow, {user, "dashboard"}, subscribe, ["$SYS/#"]}.

%% Allow clients from localhost to subscribe any topics

{allow, {ipaddr, "127.0.0.1"}, pubsub, ["$SYS/#", "#"]}.

%% Deny clients to subscribe '$SYS#' and '#'

{deny, all, subscribe, ["$SYS/#", {eq, "#"}]}.

%% Allow all by default

{allow, all}.

1. mysql插件的访问控制

MySQL 插件访问控制,通过 mqtt_acl 表定义 ACL 规则:

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;

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/#');

etc/plugins/emq_auth_mysql.conf 配置 ‘acl_query’ 与 ‘acl_nomatch’:

## ACL Query Command

##这个语句 基本不用改动,如果表名为mqtt_acl,字段也相同

auth.mysql.acl_query = select allow, ipaddr, username, clientid, access, topic from mqtt_acl where ipaddr = '%a' or username = '%u' or username = '$all' or clientid = '%c'

emq+mysql设置_EMQ--添加mysql认证及mysql插件访问控制相关推荐

  1. spark 写mysql 设置主键_Spark Sql 连接mysql

    1.基本概念和用法(摘自spark官方文档中文版) Spark SQL 还有一个能够使用 JDBC 从其他数据库读取数据的数据源.当使用 JDBC 访问其它数据库时,应该首选 JdbcRDD.这是因为 ...

  2. mysql设置参数不生效_关于mysql的wait_timeout参数 设置不生效的问题【转】

    关于wait_timeout 有一次去online set wait_timeout 的时候发现改了不生效,如下: mysql> show variables like 'wait_timeou ...

  3. mysql 设置连接超时_如何配置MySQL数据库超时设置

    最近备战京东双11,在配置MySQL的超时配置发现有很多地方可以设置.这么多超时的配置有什么影响,以及配置会有什么影响呢?今天的文章就让我来大家来分析一下. 1. JDBC超时设置 connectTi ...

  4. MySQL新建库 添加用户及权限 MySQL的Grant命令

    REATE DATABASE IF NOT EXISTS `wordpress`; GRANT ALL PRIVILEGES ON wordpress.* TO wordpress@localhost ...

  5. mysql设置约束l命令_2、MYSQL 基本数据库命令及约束

    [注]sql语句注意不要忘了后面的   "  : ",表示结束符 1.如何登陆数据库服务器 C:\Users\zhg>mysql -uroot -p Enter passwo ...

  6. mysql 指定位置添加列,如何在MySQL现有表中的特定位置添加列?

    要在现有表中的特定位置添加列,请使用after命令.语法如下-ALTER TABLE yourTableName ADD COLUMN yourColumnName data type AFTER y ...

  7. mysql 指定位置添加列_给MySQL表增加指定位置的列_MySQL

    ALTER TABLE test ADD COLUMN id INT UNSIGNED NOT NULL auto_increment PRIMARY KEY FIRST 给表添加列是一个常用的操作, ...

  8. mysql user表添加记录_《MySQL数据操作与查询》- 返校复习课练习题,创建数据库user_system,创建数据表user及user_ext...

    一.其它(共18题,100分) 1.创建数据库user_system CREATE DATABASE user_system 2.在数据库user_system中创建数据表user及user_ext, ...

  9. mysql设置查询结果最大值_查找MySQL查询结果字段的最大值

    将它连接到仅有最大计数的第二个查询.每天最内部查询(对于给定用户)每天计数的一组行数.从那以后,下一个外部执行从该集合中选择MAX()来查找并获得一个代表最高日数的记录...因为它总是返回一行,并且加 ...

  10. mac忘记mysql用户名和密码_Mac 最全 Mysql忘记用户名和密码如何处理

    工作中一直在维护开发环境和生产环境的数据库,现在想做些小测试需要用到本地库,但忘记了账户名和密码. 还好本姑娘有点儿懒,用的是navicat工具,有记录用户名,不过无所谓,都能查出来. 第一步:关闭m ...

最新文章

  1. 阿里提供中文搜索新选项!AI引擎+达摩院黑科技,你要试试吗?
  2. gets函数的不安性详解
  3. 局域网***-Dos***CDP
  4. 熊志男:写给一名测试工程师
  5. Bootstrap组件_导航条(默认样式的导航条,品牌)
  6. title与h1标签的区别和联系
  7. 系统会自带java吗_使用eclipse自带制作帮助系统
  8. PHP使用CodeIgniter笔记
  9. QLoo graphql engine 学习二 基本试用(kubernetes)
  10. 品高打造西科大教育云,带你看懂高教云建设之路
  11. #单机只打开一次窗口_单窗口单IP和单机单IP哪个好?
  12. STM32学习——半天学完正点原子入门篇例程,STM32:学会了吗?我:学废了✨
  13. 渗透测试实战分享—从app到网站沦陷
  14. xpwifi热点设置android,xp设置共享wifi热点方法分享
  15. JAVA,OpenCV简单实现“全能扫描王”的功能
  16. video标签 或 微软云 azure-media-player 禁止在iphone safari中默认全屏播放
  17. Python--print(xx)内容为空,打印不出内容;原因是文件句柄对象在迭代后,对象内的数据会逐渐清空
  18. SEO优化:6个方法提升网站排名
  19. 制造业MES生产管理系统程序代码 MES源码
  20. c语言实验3报告及答案,C语言编程实验报告3

热门文章

  1. 打趴系统的不一定是技术
  2. Cracking Wifi Wpa-Wpa2 in 5 second——Dumpper V.80.8 +JumpStart+WinPcap
  3. 【Mysql】Mysql数据表区分大小写问题解决方案
  4. ios网址解析中,中文部分如何处理
  5. Java Swing编程之仿js树状折叠菜单
  6. VC 开机自动启动程序 方法
  7. MyBatis mapper 注解过程中通过 LanguageDriver 实现动态 SQL
  8. Linux程序在预处理、编译、汇编、链接、运行步骤的作用
  9. 3Delight粒子渲染,真快。
  10. Luogu3732 [HAOI2017] 供给侧改革 【后缀数组】【线段树】【乱搞】