湛蓝之海 发表于 2021-9-29 20:42:45

MySQL 8 新特性:全局参数持久化!

自从 2018 年发布第一版 MySQL 8.0.11 正式版至今,MySQL 版本已经更新迭代到 8.0.26,相对于稳定的 5.7 版本来说,8.0 在性能上的提升是毋庸置疑的!
http://www.zzvips.com/uploads/allimg/210927/230Z12E1-0.jpg
前言
自从 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 时,可以从该配置文件获取到最新的配置参数!
: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*fromperformance_schema.persisted_variables;
Emptyset(0.00sec)


mysql>showvariableslike'%max_connections%';
+------------------------+-------+
|Variable_name|Value|
+------------------------+-------+
|max_connections|151|
|mysqlx_max_connections|100|
+------------------------+-------+
2rowsinset(0.00sec)


mysql>setpersistmax_connections=300;
QueryOK,0rowsaffected(0.00sec)


mysql>select*fromperformance_schema.persisted_variables;
+-----------------+----------------+
|VARIABLE_NAME|VARIABLE_VALUE|
+-----------------+----------------+
|max_connections|300|
+-----------------+----------------+
1rowinset(0.00sec)
系统会在数据目录下生成一个包含 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>setpersistmax_connections=DEFAULT;
QueryOK,0rowsaffected(0.00sec)


mysql>select*fromperformance_schema.persisted_variables;
+-----------------+----------------+
|VARIABLE_NAME|VARIABLE_VALUE|
+-----------------+----------------+
|max_connections|151|
+-----------------+----------------+
1rowinset(0.00sec)
如果想要移除所有的全局持久化参数,则只需执行:
mysql>RESETPERSIST;
QueryOK,0rowsaffected(0.00sec)


mysql>select*fromperformance_schema.persisted_variables;
Emptyset(0.00sec)
当然,删除 mysqld-auto.cnf 文件后,重启 MySQL 也可!
原文链接:https://mp.weixin.qq.com/s/5rBDcyYN6w13105piWaT6g

http://www.zzvips.com/article/194761.html
页: [1]
查看完整版本: MySQL 8 新特性:全局参数持久化!