MySQL8新特性之全局參數(shù)持久化詳解
前言
自從 2018 年發(fā)布第一版 MySQL 8.0.11 正式版至今,MySQL 版本已經(jīng)更新迭代到 8.0.26,相對(duì)于穩(wěn)定的 5.7 版本來說,8.0 在性能上的提升是毋庸置疑的!
隨著越來越多的企業(yè)開始使用 MySQL 8.0 版本,對(duì)于 DBA 來說是一個(gè)挑戰(zhàn),也是一個(gè)機(jī)遇!💪🏻
本文主要討論下 MySQL 8.0 版本的新特性:全局參數(shù)持久化
全局參數(shù)持久化
MySQL 8.0 版本支持在線修改全局參數(shù)并持久化,通過加上 PERSIST 關(guān)鍵字,可以將修改的參數(shù)持久化到新的配置文件(mysqld-auto.cnf)中,重啟 MySQL 時(shí),可以從該配置文件獲取到最新的配置參數(shù)!
對(duì)應(yīng)的Worklog [WL#8688]:dev.mysql.com/worklog/tas…
啟用這個(gè)功能,使用特定的語法 SET PERSIST 來設(shè)定任意可動(dòng)態(tài)修改的全局變量!
SET PERSIST
語句可以修改內(nèi)存中變量的值,并且將修改后的值寫⼊數(shù)據(jù)⽬錄中的 mysqld-auto.cnf 中。
SET PERSIST_ONLY
語句不會(huì)修改內(nèi)存中變量的值,只是將修改后的值寫⼊數(shù)據(jù)⽬錄中的 mysqld-auto.cnf 中。
以 max_connections 參數(shù)為例:
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)
系統(tǒng)會(huì)在數(shù)據(jù)目錄下生成一個(gè)包含 json 格式的 mysqld-auto.cnf 的文件,格式化后如下所示,當(dāng) my.cnf 和mysqld-auto.cnf 同時(shí)存在時(shí),后者具有更高優(yōu)先級(jí)。
{
"Version": 1,
"mysql_server": {
"max_connections": {
"Value": "300",
"Metadata": {
"Timestamp": 1632575065787609,
"User": "root",
"Host": "localhost"
}
}
}
}
📢 注意: 即使你通過 SET PERSIST 修改配置的值并沒有任何變化,也會(huì)寫入到 mysqld-auto.cnf 文件中。但你可以通過設(shè)置成 DEFAULT 值的方式來恢復(fù)初始默認(rèn)值!
如果想要恢復(fù) max_connections 參數(shù)為初始默認(rèn)值,只需要執(zhí)行:
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)
如果想要移除所有的全局持久化參數(shù),則只需執(zhí)行:
mysql> RESET PERSIST; Query OK, 0 rows affected (0.00 sec) mysql> select * from performance_schema.persisted_variables; Empty set (0.00 sec)
當(dāng)然,刪除 mysqld-auto.cnf 文件后,重啟 MySQL 也可!
寫在最后
主要代碼:
Commit f2bc0f89b7f94cc8fe963d08157413a01d14d994
主要入口函數(shù)(8.0.0):
接口函數(shù)大多定義在sql/persisted_variable.cc文件中:
啟動(dòng)時(shí)載入mysqld-auto.cnf的內(nèi)容: Persisted_variables_cache::load_persist_file(); 通過json解析合法性,并存入內(nèi)存
將文件中讀取的配置進(jìn)行設(shè)置: Persisted_variables_cache::set_persist_options
運(yùn)行SET PERSIST命令時(shí),調(diào)用Persisted_variables_cache::set_variable 更新內(nèi)存中存儲(chǔ)的值
寫入mysqld-auto.cnf文件中: Persisted_variables_cache::flush_to_file
總結(jié)
到此這篇關(guān)于MySQL8新特性之全局參數(shù)持久化的文章就介紹到這了,更多相關(guān)MySQL8全局參數(shù)持久化內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
參考文檔:
相關(guān)文章
mysql load data infile 的用法(40w數(shù)據(jù) 用了
測試數(shù)據(jù)的時(shí)候,生成txt文件應(yīng)該快點(diǎn),再用這種方式導(dǎo)入到mysql 速度上快點(diǎn),40w數(shù)據(jù) 用了3-5秒導(dǎo)進(jìn)mysql2013-01-01
MySQL報(bào)錯(cuò)Lost connection to MySQL server&n
在確保網(wǎng)絡(luò)沒有問題的情況下,服務(wù)器正常運(yùn)行一段時(shí)間后,數(shù)據(jù)庫拋出了異常"Lost connection to MySQL server during query",本文將給大家介紹MySQL報(bào)錯(cuò)Lost connection to MySQL server during query的解決方案,需要的朋友可以參考下2024-01-01
MySQL?count(*),count(id),count(1),count(字段)區(qū)別
本文主要介紹了MySQL?count(*),count(id),count(1),count(字段)區(qū)別,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-05-05
MySQL如何比較兩個(gè)表數(shù)據(jù)的差異
這篇文章主要介紹了MySQL比較兩個(gè)表數(shù)據(jù)的差異,這些方式可以根據(jù)具體需求和數(shù)據(jù)結(jié)構(gòu)選擇合適的方法來比較兩個(gè)表的數(shù)據(jù)差異,本文給大家介紹的非常詳細(xì),需要的朋友可以參考下2023-10-10
MySQL中的物理存儲(chǔ)結(jié)構(gòu)詳解
這篇文章主要介紹了MySQL中的物理存儲(chǔ)結(jié)構(gòu)用法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2025-03-03
MySQL創(chuàng)建數(shù)據(jù)庫的兩種方法
這篇文章主要為大家詳細(xì)介紹了MySQL創(chuàng)建數(shù)據(jù)庫的兩種方法,感興趣的小伙伴們可以參考一下2016-05-05

