深入讨论MySQL 8.0中的全局参数持久化

深入讨论MySQL 8.0中的全局参数持久化,第1张

概述深入讨论MySQL 8.0中的全局参数持久化 本篇文章带大家了解一下MysqL 8.0中的新特性:全局参数持久化,希望对大家有所帮助!

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

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

本文主要讨论下 MysqL 8.0 版本的新特性:全局参数持久化。【相关推荐:mysql视频教程】

全局参数持久化

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

对应的Worklog [WL#8688]:https://dev.MysqL.com/worklog/task/?ID=8688

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

SET PERSIST

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

SET PERSIST_ONLY

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

max_connections@H_301_8@ 参数为例:

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@H_301_8@ 格式的 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@H_301_8@ 修改配置的值并没有任何变化,也会写入到 MysqLd-auto.cnf 文件中。但你可以通过设置成 DEFAulT@H_301_8@ 值的方式来恢复初始默认值!

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

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

更多编程相关知识,请访问:编程视频!! 总结

以上是内存溢出为你收集整理的深入讨论MySQL 8.0中的全局参数持久化全部内容,希望文章能够帮你解决深入讨论MySQL 8.0中的全局参数持久化所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/sjk/1149978.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-31
下一篇 2022-05-31

发表评论

登录后才能评论

评论列表(0条)