加入收藏 | 设为首页 | 会员中心 | 我要投稿 温州站长网 (https://www.0577zz.com/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MySql教程 > 正文

如何领会MySQL 8.0中的全局参数持久化

发布时间:2022-01-13 13:36:01 所属栏目:MySql教程 来源:互联网
导读:本篇内容介绍了如何理解MySQL 8.0中的全局参数持久化的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成! 自从 发布第一版 MySQL 8.0.11 正式版至今,My
        本篇内容介绍了“如何理解MySQL 8.0中的全局参数持久化”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!
 
       自从  发布第一版 MySQL 8.0.11 正式版至今,MySQL 版本已经更新迭代到 8.0.26,相对于稳定的 5.7 版本来说,8.0 在性能上的提升是毋庸置疑的!
 
       随着越来越多的企业开始使用 MySQL 8.0 版本,对于 DBA 来说是一个挑战,也是一个机遇!
 
       本文主要讨论下 MySQL 8.0 版本的新特性:全局参数持久化。【相关推荐:mysql视频教程】
 
全局参数持久化
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
“如何理解MySQL 8.0中的全局参数持久化”的内容就介绍到这里了,感谢大家的阅读。

(编辑:温州站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    热点阅读