目录
前言
自从 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]:…
启用这个功能,使用特定的语法 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
总结
到此这篇关于mysql8新特性之全局参数持久化的文章就介绍到这了,更多相关mysql8全局参数持久化内容请搜索www.887551.com以前的文章或继续浏览下面的相关文章希望大家以后多多支持www.887551.com!
参考文档:
- …
- …