经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » 数据库/运维 » MySQL » 查看文章
MySQL8新特性之全局参数持久化详解
来源:jb51  时间:2021/10/11 13:08:26  对本文有异议

前言

自从 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. mysql> select * from performance_schema.persisted_variables;
  2. Empty set (0.00 sec)
  3.  
  4. mysql> show variables like '%max_connections%';
  5. +------------------------+-------+
  6. | Variable_name | Value |
  7. +------------------------+-------+
  8. | max_connections | 151 |
  9. | mysqlx_max_connections | 100 |
  10. +------------------------+-------+
  11. 2 rows in set (0.00 sec)
  12.  
  13. mysql> set persist max_connections=300;
  14. Query OK, 0 rows affected (0.00 sec)
  15.  
  16. mysql> select * from performance_schema.persisted_variables;
  17. +-----------------+----------------+
  18. | VARIABLE_NAME | VARIABLE_VALUE |
  19. +-----------------+----------------+
  20. | max_connections | 300 |
  21. +-----------------+----------------+
  22. 1 row in set (0.00 sec)

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

  1. {
  2. "Version": 1,
  3. "mysql_server": {
  4. "max_connections": {
  5. "Value": "300",
  6. "Metadata": {
  7. "Timestamp": 1632575065787609,
  8. "User": "root",
  9. "Host": "localhost"
  10. }
  11. }
  12. }
  13. }

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

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

  1. mysql> set persist max_connections=DEFAULT;
  2. Query OK, 0 rows affected (0.00 sec)
  3.  
  4. mysql> select * from performance_schema.persisted_variables;
  5. +-----------------+----------------+
  6. | VARIABLE_NAME | VARIABLE_VALUE |
  7. +-----------------+----------------+
  8. | max_connections | 151 |
  9. +-----------------+----------------+
  10. 1 row in set (0.00 sec)

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

  1. mysql> RESET PERSIST;
  2. Query OK, 0 rows affected (0.00 sec)
  3.  
  4. mysql> select * from performance_schema.persisted_variables;
  5. 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全局参数持久化内容请搜索w3xue以前的文章或继续浏览下面的相关文章希望大家以后多多支持w3xue!

参考文档:

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号