服务器之家:专注于服务器技术及软件下载分享
分类导航

Mysql|Sql Server|Oracle|Redis|MongoDB|PostgreSQL|Sqlite|DB2|mariadb|Access|数据库技术|

服务器之家 - 数据库 - Mysql - MySQL 8 新特性:全局参数持久化!

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

2021-09-27 23:08Lucifer三思而后行Lucifer Mysql

自从 2018 年发布第一版 MySQL 8.0.11 正式版至今,MySQL 版本已经更新迭代到 8.0.26,相对于稳定的 5.7 版本来说,8.0 在性能上的提升是毋庸置疑的!

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

前言

自从 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 时,可以从该配置文件获取到最新的配置参数!

[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 参数为例:

  1. mysql>select*fromperformance_schema.persisted_variables;
  2. Emptyset(0.00sec)
  3.  
  4. mysql>showvariableslike'%max_connections%';
  5. +------------------------+-------+
  6. |Variable_name|Value|
  7. +------------------------+-------+
  8. |max_connections|151|
  9. |mysqlx_max_connections|100|
  10. +------------------------+-------+
  11. 2rowsinset(0.00sec)
  12.  
  13. mysql>setpersistmax_connections=300;
  14. QueryOK,0rowsaffected(0.00sec)
  15.  
  16. mysql>select*fromperformance_schema.persisted_variables;
  17. +-----------------+----------------+
  18. |VARIABLE_NAME|VARIABLE_VALUE|
  19. +-----------------+----------------+
  20. |max_connections|300|
  21. +-----------------+----------------+
  22. 1rowinset(0.00sec)

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

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

  1. mysql>RESETPERSIST;
  2. QueryOK,0rowsaffected(0.00sec)
  3.  
  4. mysql>select*fromperformance_schema.persisted_variables;
  5. Emptyset(0.00sec)

当然,删除 mysqld-auto.cnf 文件后,重启 MySQL 也可!

原文链接:https://mp.weixin.qq.com/s/5rBDcyYN6w13105piWaT6g

延伸 · 阅读

精彩推荐
  • Mysqlmysql 常用数据库语句 小练习

    mysql 常用数据库语句 小练习

    一个mysql小练习 建表 查询 修改表 增加字段 删除字段 ...

    mysql教程网2912019-10-30
  • Mysql详解MySQL实现主从复制过程

    详解MySQL实现主从复制过程

    这篇文章主要为大家详细介绍了MySQL主从复制的实现过程,具有一定的参考价值,感兴趣的小伙伴们可以参考一下 ...

    冬瓜蔡2252020-08-03
  • MysqlMysql数据表中的蠕虫复制使用方法

    Mysql数据表中的蠕虫复制使用方法

    在本文中我们给大家分享了关于怎么使用Mysql数据表中的蠕虫复制的相关知识点,有兴趣的朋友们学习下。...

    laozhang5092019-06-07
  • MysqlMYSQL IN 与 EXISTS 的优化示例介绍

    MYSQL IN 与 EXISTS 的优化示例介绍

    当B表的数据集必须小于A表的数据集时,用in优于exists,当A表的数据集系小于B表的数据集时,用exists优于in ...

    whsnow3092020-04-15
  • Mysql教你如何使用MySQL8递归的方法

    教你如何使用MySQL8递归的方法

    这篇文章主要介绍了教你如何使用MySQL8递归的方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下...

    殷天文5262020-12-23
  • MysqlMySQL的安装与配置详细教程

    MySQL的安装与配置详细教程

    MySQL是一种关系数据库管理系统,所使用的 SQL 语言是用于访问数据库的最常用的,本文主要以Mysql免安装版为例,帮助大家解决安装与配置mysql的步骤...

    Winton-H6182021-08-24
  • Mysqlmysql如何利用binlog进行数据恢复详解

    mysql如何利用binlog进行数据恢复详解

    MySQL的binlog日志是MySQL日志中非常重要的一种日志,下面这篇文章主要给大家介绍了关于mysql如何利用binlog进行数据恢复的相关资料,文中通过示例代码介绍...

    陈芳志3352019-06-20
  • MysqlMysql 查询数据库容量大小的方法步骤

    Mysql 查询数据库容量大小的方法步骤

    这篇文章主要介绍了Mysql 查询数据库容量大小的方法步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋...

    Jevic7362021-01-21