我是靠谱客的博主 务实电话,最近开发中收集的这篇文章主要介绍acl库需要mysql吗_MySQL ACL,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

# MySQL ACL

MySQL ACL 使用外部 MySQL 数据库存储 ACL 规则,可以存储大量数据、动态管理 ACL,方便与外部设备管理系统集成

插件:

TIP

emqx_auth_mysql 插件同时包含认证功能,可通过注释禁用。

# MySQL 连接信息

MySQL 基础连接信息,需要保证集群内所有节点均能访问。

# 默认表结构

MySQL 认证插件默认配置下需要确保数据库中有以下两张数据表,用于存储认证规则信息:

# 认证/超级用户表

示例数据:

# ACL 规则表

规则表字段说明:allow:禁止(0),允许(1)

ipaddr:设置 IP 地址

username:连接客户端的用户名,此处的值如果设置为 $all 表示该规则适用于所有的用户

clientid:连接客户端的 Client ID

access:允许的操作:订阅(1),发布(2),订阅发布都可以(3)

topic:控制的主题,可以使用通配符,并且可以在主题中加入占位符来匹配客户端信息,例如 t/%c 则在匹配时主题将会替换为当前客户端的 Client ID%u:用户名

%c:Client ID

默认配置下示例数据:

启用 MySQL ACL 后并以用户名 emqx 成功连接后,客户端应当数据具有相应的主题权限。

TIP

这是默认配置使用的表结构,熟悉该插件的使用后你可以使用任何满足条件的数据表进行 ACL 规则存储。

# 超级用户 SQL(super_query)

进行 ACL 鉴权时,EMQ X 将使用当前客户端信息填充并执行用户配置的超级用户 SQL,查询客户端是否为超级用户。客户端为超级用户时将跳过 ACL SQL。

你可以在 SQL 中使用以下占位符,执行时 EMQ X 将自动填充为客户端信息:%u:用户名

%c:Client ID

%C:TLS 证书公用名(证书的域名或子域名),仅当 TLS 连接时有效

%d:TLS 证书 subject,仅当 TLS 连接时有效

你可以根据业务需要调整超级用户 SQL,如添加多个查询条件、使用数据库预处理函数,以实现更多业务相关的功能。但是任何情况下超级用户 SQL 需要满足以下条件:查询结果中必须包含 is_superuser 字段,is_superuser 应该显式的为 true

查询结果只能有一条,多条结果时只取第一条作为有效数据

TIP

如果不需要超级用户功能,注释并禁用该选项能有效提高效率

# ACL SQL(acl_query)

进行 ACL 鉴权时,EMQ X 将使用当前客户端信息填充并执行用户配置的超级用户 SQL,如果没有启用超级用户 SQL 或客户端不是超级用户,则使用 ACL SQL 查询出该客户端在数据库中的 ACL 规则。

你可以在 ACL SQL 中使用以下占位符,执行时 EMQ X 将自动填充为客户端信息:%u:用户名

%c:Client ID

%C:TLS 证书公用名(证书的域名或子域名),仅当 TLS 连接时有效

%d:TLS 证书 subject,仅当 TLS 连接时有效

你可以根据业务需要调整 ACL SQL,如添加多个查询条件、使用数据库预处理函数,以实现更多业务相关的功能。但是任何情况下 ACL SQL 需要满足以下条件:查询结果中必须包含 allow、access、topic、clientid、username、ipaddr 字段,如果字段不想参与比对则使用 $all 字符串或者数据库 NULL 值

查询结果可以有多条,多条结果时按照从上到下的顺序进行匹配

TIP

可以在 SQL 中调整查询条件、指定排序方式实现更高效率的查询。

# 特殊说明

MySQL 8.0 及以后版本使用了 caching_sha2_password 作为默认身份验证插件,受限于客户端驱动你必须将其更改为 mysql_native_password 插件:

最后

以上就是务实电话为你收集整理的acl库需要mysql吗_MySQL ACL的全部内容,希望文章能够帮你解决acl库需要mysql吗_MySQL ACL所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(46)

评论列表共有 0 条评论

立即
投稿
返回
顶部