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 @ 2021-07-16 10:42  KuBee  阅读(83)  评论(0编辑  收藏  举报