MySQL-基于(MySQL 5.7)NDB中启用共享权限表

使用共享权限表的分布式权限

通常情况下,mysql 5.7数据库中每个用户权限表都必须使用MyISAM存储引擎,这意味着在一个SQL节点上创建的用户帐户及其关联的权限在集群的其他SQL节点上是不可用的。可以在 MySQL 安装目录的 share 目录中找到随 NDB Cluster 分发提供的 SQL 文件 ndb_dist_priv.sql 使用共享权限表

1. 备份权限表数据

mysqldump options -uroot \
    mysql user db tables_priv columns_priv procs_priv proxies_priv > backup_file

其中 options 代表连接到此 SQL 节点所需的任何其他选项

2. 加载脚本

mysql options -uroot < share/ndb_dist_priv.sql

该脚本创建6个过程和1个函数对象

SELECT ROUTINE_NAME, ROUTINE_SCHEMA, ROUTINE_TYPE
    FROM INFORMATION_SCHEMA.ROUTINES
    WHERE ROUTINE_NAME LIKE 'mysql_cluster%'
    ORDER BY ROUTINE_TYPE;

image-20210716102548319

3. 转换存储引擎

CALL mysql.mysql_cluster_move_privileges();

-- 检查转换是否成功
SELECT CONCAT(
    'Conversion ',
    IF(mysql.mysql_cluster_privileges_are_distributed(), 'succeeded', 'failed'),
    '.')
    AS Result;

4. 检查备份是否成功

SELECT TABLE_NAME, ENGINE FROM INFORMATION_SCHEMA.TABLES
     WHERE TABLE_SCHEMA = 'mysql' AND TABLE_NAME LIKE '%backup'
     ORDER BY ENGINE;

image-20210716103601224

至此,分布式权限已启用。后面新增的用户,删除用户或权限更新都会影响集群中的所有MySQL Server。

posted @   KuBee  阅读(89)  评论(0编辑  收藏  举报
编辑推荐:
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
阅读排行:
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· .NET10 - 预览版1新功能体验(一)
点击右上角即可分享
微信分享提示

目录导航