Maison  >  Article  >  base de données  >  Une discussion approfondie sur la persistance des paramètres globaux dans MySQL 8.0

Une discussion approfondie sur la persistance des paramètres globaux dans MySQL 8.0

青灯夜游
青灯夜游avant
2021-10-15 18:32:421882parcourir

Cet article vous présentera les nouvelles fonctionnalités de MySQL 8.0 : persistance des paramètres globaux. J'espère qu'il vous sera utile !

Une discussion approfondie sur la persistance des paramètres globaux dans MySQL 8.0

Depuis la sortie de la version officielle de la première version MySQL 8.0.11 en 2018, la version MySQL a été mise à jour et itérée vers 8.0.26, par rapport à la version stable 5.7 En termes de performances, il ne fait aucun doute que la 8.0 a amélioré les performances ! 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

Alors que de plus en plus d'entreprises commencent à utiliser la version MySQL 8.0, c'est un défi et une opportunité pour les DBA !

Cet article traite principalement des nouvelles fonctionnalités de la version MySQL 8.0 :

Persistance des paramètres globaux

. [Recommandations associées : mysql video tutoriel

]

Paramètres globaux Persistance

MySQL version 8.0 prend en charge la modification en ligne des paramètres globaux et la persistance. En ajoutant le mot-clé PERSIST, les paramètres modifiés peuvent être conservés dans le nouveau fichier de configuration (mysqld-auto.cnf), lors du redémarrage. MySQL, les derniers paramètres de configuration peuvent être obtenus à partir de ce fichier de configuration !

Journal de travail correspondant [WL#8688] : https://dev.mysql.com/worklog/task/?id=8688

Activez cette fonctionnalité et utilisez une syntaxe spécifiqueSET PERSIST pour définir n'importe quelle variable globale pouvant être modifiée dynamiquement !

  • SET PERSIST

L'instruction peut modifier la valeur de la variable dans la mémoire et écrire la valeur modifiée dans mysqld dans le répertoire de données -auto.cnf.
  • 🎜SET PERSIST_ONLY🎜
🎜L'instruction ne modifie pas la valeur de la variable dans la mémoire, mais écrit uniquement la valeur modifiée dans les données répertoire mysqld-auto.cnf. 🎜🎜🎜Prenons le paramètre max_connections comme exemple : 🎜🎜
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)
🎜Le système générera un fichier mysqld-auto.cnf contenant le format json dans le répertoire de données. Comme indiqué ci-dessous, lorsque my.cnf et mysqld-auto.cnf existent en même temps, ce dernier a une priorité plus élevée. 🎜
mysql> RESET PERSIST;
Query OK, 0 rows affected (0.00 sec)

mysql> select * from performance_schema.persisted_variables;
Empty set (0.00 sec)
🎜🎜Remarque : 🎜 Même si vous modifiez la valeur de configuration via SET PERSIST et qu'il n'y a aucun changement, elle sera également écrite dans le fichier mysqld-auto.cnf. Mais vous pouvez restaurer la valeur par défaut initiale en la définissant sur la valeur DEFAULT ! 🎜🎜Si vous souhaitez restaurer le paramètre max_connections à sa valeur par défaut initiale, exécutez simplement : 🎜
接口函数大多定义在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
🎜Si vous souhaitez supprimer tous les paramètres de persistance globaux, exécutez simplement : 🎜rrreee🎜Bien sûr, supprimez mysqld -auto.cnf, vous pouvez également redémarrer MySQL ! 🎜🎜🎜Écrit à la fin🎜🎜🎜🎜Code principal : 🎜🎜Commit f2bc0f89b7f94cc8fe963d08157413a01d14d994🎜🎜🎜🎜Fonction d'entrée principale (8.0.0) : reee 🎜Pour plus de connaissances sur la programmation, veuillez visiter : 🎜Vidéos de programmation🎜 ! ! 🎜

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Cet article est reproduit dans:. en cas de violation, veuillez contacter admin@php.cn Supprimer