MySQL8新特性之全局参数持久化详解

作者:Lucifer三思而后行 时间:2024-01-23 12:17:10 

目录
  • 前言

  • 全局参数持久化

  • 写在最后

  • 总结

  • 参考文档:

前言

自从 2018 年发布第一版 MySQL 8.0.11 正式版至今,MySQL 版本已经更新迭代到 8.0.26,相对于稳定的 5.7 版本来说,8.0 在性能上的提升是毋庸置疑的!

随着越来越多的企业开始使用 MySQL 8.0 版本,对于 DBA 来说是一个挑战,也是一个机遇!💪🏻

本文主要讨论下 MySQL 8.0 版本的新特性:全局参数持久化

全局参数持久化

MySQL 8.0 版本支持在线修改全局参数并持久化,通过加上 PERSIST 关键字,可以将修改的参数持久化到新的配置文件(mysqld-auto.cnf)中,重启 MySQL 时,可以从该配置文件获取到最新的配置参数!

对应的Worklog [WL#8688]:dev.mysql.com/worklog/tas…

启用这个功能,使用特定的语法 SET PERSIST 来设定任意可动态修改的全局变量!

SET PERSIST

语句可以修改内存中变量的值,并且将修改后的值写⼊数据⽬录中的 mysqld-auto.cnf 中。

SET PERSIST_ONLY

语句不会修改内存中变量的值,只是将修改后的值写⼊数据⽬录中的 mysqld-auto.cnf 中。

以 max_connections 参数为例:


mysql> select * from performance_schema.persisted_variables;
Empty set (0.00 sec)

mysql> show variables like '%max_connections%';
+------------------------+-------+
| Variable_name          | Value |
+------------------------+-------+
| max_connections        | 151   |
| mysqlx_max_connections | 100   |
+------------------------+-------+
2 rows in set (0.00 sec)

mysql> set persist max_connections=300;
Query OK, 0 rows affected (0.00 sec)

mysql> select * from performance_schema.persisted_variables;
+-----------------+----------------+
| VARIABLE_NAME   | VARIABLE_VALUE |
+-----------------+----------------+
| max_connections | 300            |
+-----------------+----------------+
1 row in set (0.00 sec)

系统会在数据目录下生成一个包含 json 格式的 mysqld-auto.cnf 的文件,格式化后如下所示,当 my.cnf 和mysqld-auto.cnf 同时存在时,后者具有更高优先级。


{
   "Version": 1,
   "mysql_server": {
       "max_connections": {
           "Value": "300",
           "Metadata": {
               "Timestamp": 1632575065787609,
               "User": "root",
               "Host": "localhost"
           }
       }
   }
}

📢 注意: 即使你通过 SET PERSIST 修改配置的值并没有任何变化,也会写入到 mysqld-auto.cnf 文件中。但你可以通过设置成 DEFAULT 值的方式来恢复初始默认值!

如果想要恢复 max_connections 参数为初始默认值,只需要执行:


mysql> set persist max_connections=DEFAULT;
Query OK, 0 rows affected (0.00 sec)

mysql> select * from performance_schema.persisted_variables;
+-----------------+----------------+
| VARIABLE_NAME   | VARIABLE_VALUE |
+-----------------+----------------+
| max_connections | 151            |
+-----------------+----------------+
1 row in set (0.00 sec)

如果想要移除所有的全局持久化参数,则只需执行:


mysql> RESET PERSIST;
Query OK, 0 rows affected (0.00 sec)

mysql> select * from performance_schema.persisted_variables;
Empty set (0.00 sec)

当然,删除 mysqld-auto.cnf 文件后,重启 MySQL 也可!

写在最后

主要代码:

Commit f2bc0f89b7f94cc8fe963d08157413a01d14d994

主要入口函数(8.0.0):

接口函数大多定义在sql/persisted_variable.cc文件中:
启动时载入mysqld-auto.cnf的内容: Persisted_variables_cache::load_persist_file(); 通过json解析合法性,并存入内存
将文件中读取的配置进行设置: Persisted_variables_cache::set_persist_options
 
运行SET PERSIST命令时,调用Persisted_variables_cache::set_variable 更新内存中存储的值
写入mysqld-auto.cnf文件中: Persisted_variables_cache::flush_to_file

参考文档:

  • mysqlserverteam.com/mysql-8-0-p…

  • dev.mysql.com/worklog/tas…

  • bugs.mysql.com/bug.php?id=…

来源:https://juejin.cn/post/7017284732182331422

标签:mysql8,新特性,全局参数
0
投稿

猜你喜欢

  • MySql采用GROUP_CONCAT合并多条数据显示的方法

    2024-01-20 07:39:22
  • Python+PyQT5实现手绘图片生成器

    2022-03-11 11:57:21
  • Python实现通讯录功能

    2022-06-28 22:33:26
  • Python中的对象,方法,类,实例,函数用法分析

    2022-12-13 22:01:38
  • python 实现端口扫描工具

    2022-12-05 23:02:45
  • 详解python做UI界面的方法

    2023-05-24 08:07:41
  • JS+HTML5 canvas绘制验证码示例

    2023-07-19 11:23:53
  • Django 解决distinct无法去除重复数据的问题

    2023-02-09 22:13:22
  • 最新Listary v5.00.2843注册码 亲测可用

    2022-07-04 22:20:43
  • python爬虫headers设置后无效的解决方法

    2021-09-04 00:55:17
  • 如何用Python获取计算机名,ip地址,mac地址

    2021-12-31 05:41:04
  • Python GUI之tkinter详解

    2021-09-11 06:36:01
  • oracle 存储过程加密的方法

    2009-03-06 10:58:00
  • Microsoft VBScript 运行时错误 错误 800a0005 无效的过程调用或参数: chr

    2011-03-09 11:03:00
  • python实战scrapy操作cookie爬取博客涉及browsercookie

    2023-08-13 16:56:00
  • python画微信表情符的实例代码

    2022-01-09 07:06:40
  • Python办公自动化SFTP详解

    2021-10-11 13:04:27
  • SQL Server无日志恢复数据库(2种方法)

    2024-01-17 03:40:56
  • 小技巧解决“FF不能读取outerHTML”的问题

    2009-02-10 10:44:00
  • 聊聊MySQL中的参数

    2024-01-24 20:47:01
  • asp之家 网络编程 m.aspxhome.com