本文已参与「掘力星计划」,赢取创作大礼包,挑战创作激励金。
前言
自从 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
参数为例:
1 | sql复制代码mysql> select * from performance_schema.persisted_variables; |
系统会在数据目录下生成一个包含 json
格式的 mysqld-auto.cnf 的文件,格式化后如下所示,当 my.cnf 和mysqld-auto.cnf 同时存在时,后者具有更高优先级。
1 | json复制代码{ |
📢 注意: 即使你通过 SET PERSIST
修改配置的值并没有任何变化,也会写入到 mysqld-auto.cnf 文件中。但你可以通过设置成 DEFAULT
值的方式来恢复初始默认值!
如果想要恢复 max_connections
参数为初始默认值,只需要执行:
1 | sql复制代码mysql> set persist max_connections=DEFAULT; |
如果想要移除所有的全局持久化参数,则只需执行:
1 | sql复制代码mysql> RESET PERSIST; |
当然,删除 mysqld-auto.cnf 文件后,重启 MySQL 也可!
写在最后
主要代码:
Commit f2bc0f89b7f94cc8fe963d08157413a01d14d994
主要入口函数(8.0.0):
1 | arduino复制代码接口函数大多定义在sql/persisted_variable.cc文件中: |
参考文档:
本次分享到此结束啦~
如果觉得文章对你有帮助,点赞、收藏、关注、评论,一键四连支持,你的支持就是我创作最大的动力。
❤️ 技术交流可以 关注公众号:Lucifer三思而后行 ❤️
本文转载自: 掘金