在线精品99_中国九九盗摄偷拍偷看_91免费版在线观看_91.app_91高清视频在线_99热最新网站

如何理解MySQL 8.0中的全局参数持久化

109次阅读
没有评论

共计 2633 个字符,预计需要花费 7 分钟才能阅读完成。

本篇内容介绍了“如何理解 MySQL 8.0 中的全局参数持久化”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让丸趣 TV 小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

自从 2018 年发布第一版 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]: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 中的全局参数持久化”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注丸趣 TV 网站,丸趣 TV 小编将为大家输出更多高质量的实用文章!

正文完
 
丸趣
版权声明:本站原创文章,由 丸趣 2023-07-27发表,共计2633字。
转载说明:除特殊说明外本站除技术相关以外文章皆由网络搜集发布,转载请注明出处。
评论(没有评论)
主站蜘蛛池模板: 白白在线观看永久免费视频 | 午夜国产精品久久久久 | 亚洲国产av无码综合原创国产 | 久久99精品久久久久久hb无码 | 国产午夜看片 | 亚洲精品久久久久网站 | 亚洲欧美综合在线观看 | 性感美女一级毛片 | 久久精品视频16 | 一本色道久久88综合日韩精品 | 欧美日韩三级 | 自拍偷拍视频在线 | 中国gay片男同志免费网站 | 一本本月无码- | 中国人妻被两个老外三p | 在线观看精品视频网站www | 国产超碰人人模人人爽人人添 | 国产目拍亚洲精品一区二区三区 | 久久天天躁狠狠躁夜夜av | 亚洲av无码专区国产不卡顿 | 欧美日产国产精品 | 亚洲欧美日韩中文字幕在线一区 | 成人天堂资源www在线 | 91精品国产91久久久久久 | 欧美性xxxx极品hd欧美风情 | 自拍偷自拍亚洲精品播放 | 国产精品99久久99久久久动漫 | 无码aⅴ在线观看 | 欧美日韩一区二区三区视频播 | 亚洲av日韩av高潮潮喷无码 | 亚洲国产精品日韩av不卡在线 | 你懂的免费网址 | 久久久久成人精品一区二区 | 日产精品卡2卡三卡乱码网站 | 国产无遮挡无码视频在线观看 | 国产亚洲蜜芽精品久久 | 午夜在线观看免费高清在线播放 | 一级aaaaaa片毛片在线播放 | 国产成人毛片视频不卡在线 | 深夜福利视频在线观看免费视频 | 成人做爰|