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;
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。
分类:
数据库(MySQL)
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· .NET10 - 预览版1新功能体验(一)