首页数据库MySQL 8.0中的全局参数持久化怎样理解?

MySQL 8.0中的全局参数持久化怎样理解?

时间2024-03-24 12:20:03发布访客分类数据库浏览386
导读:这篇文章我们来了解MySQL 8.0中的一个特性,也就是全局参数持久化。那么究竟全局参数持久化是什么意思,怎样理解呢?下文有很详细的介绍,有需要的朋友可以了解一下,接下来就跟随小编来看看吧!全局参数持久化MySQL 8.0 版本支持在线修改...

这篇文章我们来了解MySQL 8.0中的一个特性,也就是全局参数持久化。那么究竟全局参数持久化是什么意思,怎样理解呢?下文有很详细的介绍,有需要的朋友可以了解一下,接下来就跟随小编来看看吧!

全局参数持久化

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

对应的Worklog [WL#8688]:https://dev.mysql.com/worklog/task/?id=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中的全局参数持久化就介绍到这,上述示例SQL语句对大家理解全局参数持久化有一定的帮助,需要的朋友可以参考。最后,想要了解更多全局参数持久化的内容,大家可以关注其它的相关文章。

文本转载自PHP中文网

声明:本文内容由网友自发贡献,本站不承担相应法律责任。对本内容有异议或投诉,请联系2913721942#qq.com核实处理,我们将尽快回复您,谢谢合作!


若转载请注明出处: MySQL 8.0中的全局参数持久化怎样理解?
本文地址: https://pptw.com/jishu/652055.html
分布式事务的解决方案有哪些?你了解多少? 去除数组中的空元素,php怎么做

游客 回复需填写必要信息