国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁(yè) > 數(shù)據(jù)庫(kù) > MySQL > 正文

MySQL8新特性:持久化全局變量的修改方法

2024-07-24 12:50:03
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

前言

在8之前的版本中,對(duì)于全局變量的修改,其只會(huì)影響其內(nèi)存值,而不會(huì)持久化到配置文件中。數(shù)據(jù)庫(kù)重啟,又會(huì)恢復(fù)成修改前的值。從8開始,可通過(guò)SET PERSIST命令將全局變量的修改持久化到配置文件中。

試舉一例

mysql> show variables like '%max_connections%';+------------------------+-------+| Variable_name | Value |+------------------------+-------+| max_connections | 151 || mysqlx_max_connections | 100 |+------------------------+-------+rows in set (0.00 sec)mysql> set persist max_connections=200;Query OK, 0 rows affected (0.00 sec)mysql> show variables like '%max_connections%';+------------------------+-------+| Variable_name | Value |+------------------------+-------+| max_connections | 200 || mysqlx_max_connections | 100 |+------------------------+-------+rows in set (0.00 sec)

全局變量的修改會(huì)保存在兩處,

1.  數(shù)據(jù)目錄下mysqld-auto.cnf文件,

     注意,不是啟動(dòng)時(shí)--defaults-file指定的配置文件。

[root@slowtech ~]# cat /var/lib/mysql/mysqld-auto.cnf { "Version" : 1 , "mysql_server" : { "max_connections" : { "Value" : "200" , "Metadata" : { "Timestamp" : 1525509217566258 , "User" : "root" , "Host" : "localhost" } } } }

持久化信息以json格式保存,其中,Metadata記錄了這次修改的用戶及時(shí)間信息。

在數(shù)據(jù)庫(kù)啟動(dòng)時(shí),會(huì)首先讀取其它配置文件,最后才讀取mysqld-auto.cnf文件。不建議手動(dòng)修改該文件,其有可能導(dǎo)致數(shù)據(jù)庫(kù)在啟動(dòng)過(guò)程中因解析錯(cuò)誤而失敗。如果出現(xiàn)這種情況,可手動(dòng)刪除mysqld-auto.cnf文件或?qū)ersisted_globals_load變量設(shè)置為off來(lái)避免該文件的加載。

2. performance_schema.persisted_variables

mysql> select * from performance_schema.persisted_variables;+-----------------+----------------+| VARIABLE_NAME | VARIABLE_VALUE |+-----------------+----------------+| max_connections | 200 |+-----------------+----------------+row in set (0.00 sec)

全局變量的持久化除了SET PERSIST外,還有SET PERSIST_ONLY,與前者相比,其只持久化全局變量,而不修改其內(nèi)存值。同時(shí),在權(quán)限方面,前者只需要SYSTEM_VARIABLES_ADMIN,后者還需要PERSIST_RO_VARIABLES_ADMIN權(quán)限。

對(duì)于已經(jīng)持久化了變量,可通過(guò)RESET PERSIST命令清除掉,注意,其只是清空mysqld-auto.cnf和performance_schema.persisted_variables中的內(nèi)容,對(duì)于已經(jīng)修改了的變量的值,不會(huì)產(chǎn)生任何影響。

除此之外,還可以通過(guò)下述方式將全局變量持久化為默認(rèn)值。注意,是默認(rèn)值,而不是修改前的值。

mysql> set persist max_connections=default;

這個(gè)命令同“set global max_connections=default

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 中山市| 漯河市| 厦门市| 咸丰县| 庄浪县| 马龙县| 肇庆市| 兰考县| 平陆县| 尼玛县| 团风县| 吕梁市| 呼图壁县| 若羌县| 通城县| 祁连县| 板桥市| 老河口市| 辽阳县| 岐山县| 瑞安市| 德阳市| 卢湾区| 来安县| 慈利县| 綦江县| 九寨沟县| 绥德县| 海晏县| 惠州市| 商水县| 崇仁县| 丰都县| 鸡泽县| 色达县| 昌江| 麻阳| 合作市| 江山市| 定陶县| 崇礼县|