当前位置: 首页 > news >正文

MySQL中的系统变量权限

MySQL的系统变量用于控制服务器的操作。它们可以是全局的(影响整个MySQL服务器实例),也可以是会话的(仅影响当前客户端会话),或者两者兼有。

你可以使用SET语句来动态地改变这些变量的值。例如:

  • 设置全局系统变量的运行时值

使用set global语句,该语句需要system_VARIABLES_ADMIN权限(或不推荐使用的SUPER权限)。例如:

SET GLOBAL max_connections = 1000;
  • 设置会话变量(仅影响当前会话):
SET SESSION sort_buffer_size = 256K;
  • 将全局系统变量的值持久化到 mysqld-auto.cnf 文件(并设置运行时值)

使用set persist语句,该语句需要system_VARIABLES_ADMIN或SUPER权限。

  • 仅将全局系统变量的值持久化到 mysqld-auto.cnf 文件(不设置运行时值)

使用SET persist_ONLY语句,该语句需要system_VARIABLES_ADMIN和persist_RO_VARIABLES_ADMIN权限。SET PERSIST_ONLY既可用于动态系统变量,也可用于只读系统变量,但对于不能使用SET PERSIST的持久只读变量特别有用。

  • 持久化限制的系统变量

一些全局系统变量是持久受限的。要持久化这些变量,请使用SET persist_ONLY语句,该语句需要前面描述的权限。此外,必须使用加密连接连接到服务器,并提供具有由persist_only_admin_x509_Subject系统变量指定的Subject值的SSL证书。

例如:

SET PERSIST max_connections = 1000;

或者:

SET GLOBAL PERSIST max_connections = 1000;

要从mysqld-auto.cnf文件中删除持久化的全局系统变量,请使用RESET PERSIST语句。这些特权适用于:

  • 对于动态系统变量,RESET PERSIST需要system_variables_ADMIN或SUPER权限。
  • 对于只读系统变量,RESET PERSIST需要system_variables_ADMIN和PERSIST_RO_variables_ADMIN权限。
  • 对于持久受限变量,RESET persist不需要使用特定SSL证书加密连接到服务器。

例如:

RESET PERSIST max_connections;

如果全局系统变量对前面的特权要求有任何异常,则变量描述会指示这些异常。示例包括default_table_encryption和commandory_roles,它们需要额外的权限。这些附加权限适用于设置全局运行时值的操作,但不适用于保留该值的操作。

要设置会话系统变量运行时值,请使用set session语句。与设置全局运行时值相比,设置会话运行时值通常不需要特殊权限,任何用户都可以进行设置以影响当前会话。对于某些系统变量,设置会话值可能会在当前会话之外产生影响,因此这是一项受限制的操作,只能由具有特殊权限的用户执行:

  • 从MySQL 8.0.14开始,所需的权限为SESSION_VARIABLES_ADMIN。

任何具有SYSTEM_VARIABLES_ADMIN或SUPER的用户实际上隐含地具有SESSION_VARIABLES _ADMIN,并且无需明确授予SESSION_VARIABLES_AADMIN。

  • 在MySQL 8.0.14之前,所需的权限是SYSTEM_VARIABLES_ADMIN或SUPER。

如果会话系统变量受到限制,则变量描述会指示该限制。示例包括binlog_format和sql_log_bin。设置这些变量的会话值会影响当前会话的二进制日志记录,但也可能对服务器复制和备份的完整性产生更广泛的影响。

SESSION_VARIABLES_ADMIN使管理员能够最大限度地减少先前可能已被授予SYSTEM_VARIABLES _ADMIN或SUPER的用户的权限占用,以使他们能够修改受限制的会话系统变量。假设管理员创建了以下角色以授予设置受限会话系统变量的能力:

CREATE ROLE set_session_sysvars;
GRANT SYSTEM_VARIABLES_ADMIN ON *.* TO set_session_sysvars;

任何被授予set_session_sysvars角色的用户(以及该角色处于活动状态的用户)都可以设置受限制的会话系统变量。然而,该用户也能够设置全局系统变量,这可能是不希望的。

通过将角色修改为具有SESSION_VARIABLES_ADMIN而不是SYSTEM_VARIABLES _ADMIN,可以将角色权限减少为设置受限会话系统变量的能力,而不设置其他内容。要修改角色,请使用以下语句:

GRANT SESSION_VARIABLES_ADMIN ON *.* TO set_session_sysvars;
REVOKE SYSTEM_VARIABLES_ADMIN ON *.* FROM set_session_sysvars;

修改角色会立即生效:任何被授予set_session_sysvars角色的帐户都不再具有SYSTEM_VARIABLES_ADMIN,并且在没有明确授予该功能的情况下无法设置全局系统变量。类似的GRANT/REVOKE序列可以应用于直接授予SYSTEM_VARIABLES_ADMIN而不是通过角色授予的任何帐户。

相关文章:

  • 字节跳动:从梦想之芽到参天大树
  • 二叉树经典OJ练习
  • Webfunny【用户细查】七项功能升级更新:大幅提升用户排查效率!
  • CLIP-ReID代码解读七——model.py上
  • gitee添加别人的仓库后,在该仓库里添加文件夹/文件
  • 协程执行顺序引发的问题
  • 如何配置taro
  • C++STL 初阶(5)vector的简易实现(上)
  • [MRCTF2020]PixelShooter
  • Jenkins+K8s实现持续集成(一)
  • 晶谷电子器件烧结封装介质材料 绝缘用晶谷低温封接环保玻璃粉 耐压高
  • git stash Pop 后丢失,要如何找回?
  • python输入、输出和变量
  • Java——集合(一)
  • flex布局无法设置图片icon和文本垂直居中对齐问题
  • [微信小程序] 使用ES6特性Class后出现编译异常
  • android图片蒙层
  • CNN 在图像分割中的简史:从 R-CNN 到 Mask R-CNN
  • docker容器内的网络抓包
  • download使用浅析
  • Druid 在有赞的实践
  • in typeof instanceof ===这些运算符有什么作用
  • input的行数自动增减
  • javascript数组去重/查找/插入/删除
  • js 实现textarea输入字数提示
  • Laravel5.4 Queues队列学习
  • mysql中InnoDB引擎中页的概念
  • vue 配置sass、scss全局变量
  • Vue.js 移动端适配之 vw 解决方案
  • 阿里云前端周刊 - 第 26 期
  • 阿里云应用高可用服务公测发布
  • 聚类分析——Kmeans
  • 函数计算新功能-----支持C#函数
  • 如何用纯 CSS 创作一个货车 loader
  • ​sqlite3 --- SQLite 数据库 DB-API 2.0 接口模块​
  • ​创新驱动,边缘计算领袖:亚马逊云科技海外服务器服务再进化
  • ######## golang各章节终篇索引 ########
  • #WEB前端(HTML属性)
  • #免费 苹果M系芯片Macbook电脑MacOS使用Bash脚本写入(读写)NTFS硬盘教程
  • (7)svelte 教程: Props(属性)
  • (C#)Windows Shell 外壳编程系列4 - 上下文菜单(iContextMenu)(二)嵌入菜单和执行命令...
  • (C++)栈的链式存储结构(出栈、入栈、判空、遍历、销毁)(数据结构与算法)
  • (二)基于wpr_simulation 的Ros机器人运动控制,gazebo仿真
  • (六)什么是Vite——热更新时vite、webpack做了什么
  • (七)Knockout 创建自定义绑定
  • (三) prometheus + grafana + alertmanager 配置Redis监控
  • (转)GCC在C语言中内嵌汇编 asm __volatile__
  • (转)Google的Objective-C编码规范
  • (转)MVC3 类型“System.Web.Mvc.ModelClientValidationRule”同时存在
  • (转)socket Aio demo
  • (轉貼) UML中文FAQ (OO) (UML)
  • .NET Entity FrameWork 总结 ,在项目中用处个人感觉不大。适合初级用用,不涉及到与数据库通信。
  • .net mvc部分视图
  • .net SqlSugarHelper
  • .NET 程序如何获取图片的宽高(框架自带多种方法的不同性能)