前言

自从 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)
{    "Version": 1,     "mysql_server": {        "max_connections": {            "Value": "300",             "Metadata": {                "Timestamp": 1632575065787609,                 "User": "root",                 "Host": "localhost"            }        }    }}

如果想要恢复 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)

写在最后

主要代码:

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

总结

更多相关文章

  1. MySQL系列多表连接查询92及99语法示例详解教程
  2. Android(安卓)- Manifest 文件 详解
  3. Android的Handler机制详解3_Looper.looper()不会卡死主线程
  4. Selector、shape详解(一)
  5. 链接器解析多重定义的全局变量
  6. android2.2资源文件详解4--menu文件夹下的菜单定义
  7. Android发送短信方法实例详解
  8. Android(安卓)读取资源文件实例详解
  9. 详解Android中的屏幕方向

随机推荐

  1. PHP协程框架Hyperf日志查看组件
  2. 解析PHP标准库SPL数据结构
  3. 创建 PSR-4 的 Php 包
  4. 看看PHP 多进程处理任务
  5. 一定要改掉 这5个PHP编程中的不良习惯!
  6. PHP安全问题汇总
  7. 详解PHP中被忽略的性能优化利器:生成器
  8. 教你使用PHP实现查找你想要的附近人
  9. 你可能要纠正这5个PHP编码小陋习!
  10. PHP处理时间和时区需注意以下三点!