使用共享权限表的分布式权限
通常情况下,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;
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;
至此,分布式权限已启用。后面新增的用户,删除用户或权限更新都会影响集群中的所有MySQL Server。