>  기사  >  데이터 베이스  >  MySQL 8.0의 전역 매개변수 지속성에 대한 심층적인 논의

MySQL 8.0의 전역 매개변수 지속성에 대한 심층적인 논의

青灯夜游
青灯夜游앞으로
2021-10-15 18:32:421841검색

이 기사에서는 MySQL 8.0의 새로운 기능인 전역 매개변수 지속성에 대해 설명합니다. 도움이 되기를 바랍니다.

MySQL 8.0의 전역 매개변수 지속성에 대한 심층적인 논의

2018년 첫 번째 버전 MySQL 8.0.11의 공식 버전이 출시된 이후, MySQL 버전은 8.0.26으로 업데이트 및 반복되었으며, 이에 비해 안정적인 5.7 버전으로 성능면에서 8.0에서 성능이 향상되었다는 것은 의심의 여지가 없습니다! 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 8.0 버전을 사용하기 시작하면서 이는 DBA에게 도전이자 기회입니다!

이 문서에서는 주로 MySQL 8.0 버전의 새로운 기능인

전역 매개변수 지속성

에 대해 설명합니다. [관련 권장사항: mysql 비디오 튜토리얼

]

전역 매개변수 Persistence

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 매개변수를 예로 들어보세요. 🎜🎜
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)
🎜시스템은 포맷 후 데이터 디렉토리에 json 형식을 포함하는 mysqld-auto.cnf 파일을 생성합니다. 아래와 같이 my.cnf와 mysqld-auto.cnf가 동시에 존재할 경우 후자가 더 높은 우선순위를 갖는다. 🎜
mysql> RESET PERSIST;
Query OK, 0 rows affected (0.00 sec)

mysql> select * from performance_schema.persisted_variables;
Empty set (0.00 sec)
🎜🎜참고: 🎜 SET PERSIST를 통해 구성 값을 수정하고 변경 사항이 없더라도 mysqld-auto.cnf 파일에도 기록됩니다. 하지만 DEFAULT 값으로 설정하면 초기 기본값을 복원할 수 있습니다! 🎜🎜max_connections 매개변수를 초기 기본값으로 복원하려면 다음을 실행하세요. 🎜
接口函数大多定义在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
🎜모든 전역 지속성 매개변수를 제거하려면 다음을 실행하세요. 🎜rrreee🎜물론 mysqld를 삭제하세요. -auto.cnf 파일을 사용하면 MySQL을 다시 시작할 수도 있습니다! 🎜🎜🎜마지막에 작성🎜🎜🎜🎜메인코드 : 🎜🎜Commit f2bc0f89b7f94cc8fe963d08157413a01d14d994🎜🎜🎜🎜메인입력기능 (8.0.0) : 🎜 🎜rrreee 🎜더 많은 프로그래밍 관련 지식을 보려면 🎜프로그래밍 비디오🎜를 방문하세요! ! 🎜

위 내용은 MySQL 8.0의 전역 매개변수 지속성에 대한 심층적인 논의의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
이 기사는 juejin.cn에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제