zoukankan      html  css  js  c++  java
  • 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。

  • 相关阅读:
    FilterLog代码分析
    Session
    关于XML的技术详情----XML定义 用途 工作原理及未来
    javaee思维导图
    互联网应用与企业级应用的区别
    javaee课程目标
    Recycle -- 项目总结
    python3.6学习笔记2基础语法
    python3.6学习笔记1认识python
    CentOS6.5下Virtualenv搭建Python3开发环境
  • 原文地址:https://www.cnblogs.com/binliubiao/p/15019030.html
Copyright © 2011-2022 走看看