mysql設置環境變量

-- 設置或修改系統日誌有效期
SET GLOBAL expire_logs_days=8;
SHOW VARIABLES LIKE '%expire_logs_days%';




-- 設置或修改系統最大連接數
SET GLOBAL max_connections = 2648;
SHOW VARIABLES LIKE '%max_connections%';




-- 修改MYSQL自動編號步長
SHOW VARIABLES LIKE '%auto_increment%';
SET GLOBAL auto_increment_offset = 1;
SET GLOBAL auto_increment_increment = 1;




比如設置MySQL實例參數wait_timeout爲10秒.
1) 設置全局變量方法1(不推薦): 修改參數文件, 然後重啓mysqld
# vi /etc/my.cnf
[mysqld]
wait_timeout=10
# service mysqld restart
不過這個方法太生硬了, 線上服務重啓無論如何都應該儘可能避免.
 
2) 設置全局變量方法2(推薦): 在命令行裏通過SET來設置, 然後再修改參數文件
如果要修改全局變量, 必須要顯示指定"GLOBAL"或者"@@global.", 同時必須要有SUPER權限. 
mysql> set global wait_timeout=10;
or
mysql> set @@global.wait_timeout=10;
 
然後查看設置是否成功:
mysql> select @@global.wait_timeout=10;
or
mysql> show global variables like 'wait_timeout';
+---------------+-------+
| Variable_name | Value |
+---------------+-------+
| wait_timeout  | 10    | 
+---------------+-------+
如果查詢時使用的是show variables的話, 會發現設置並沒有生效, 除非重新登錄再查看. 這是因爲使用show variables的話就等同於使用show session variables, 查詢的是會話變量, 只有使用show global variables查詢的纔是全局變量. 如果僅僅想修改會話變量的話, 可以使用類似set wait_timeout=10;或者set session wait_timeout=10;這樣的語法. 
當前只修改了正在運行的MySQL實例參數, 但下次重啓mysqld又會回到默認值, 所以別忘了修改參數文件:
# vi /etc/my.cnf
[mysqld]
wait_timeout=10


3) 設置會話變量方法: 在命令行裏通過SET來設置
如果要修改會話變量值, 可以指定"SESSION"或者"@@session."或者"@@"或者"LOCAL"或者"@@local.", 或者什麼都不使用. 
mysql> set wait_timeout=10;
or
mysql> set session wait_timeout=10;
or
mysql> set local wait_timeout=10;
or
mysql> set @@wait_timeout=10;
or
mysql> set @@session.wait_timeout=10;
or
mysql> set @@local.wait_timeout=10;
 
然後查看設置是否成功:
mysql> select @@wait_timeout;
or
mysql> select @@session.wait_timeout;
or
mysql> select @@local.wait_timeout;
or
mysql> show variables like 'wait_timeout';
or
mysql> show local variables like 'wait_timeout';
or
mysql> show session variables like 'wait_timeout';
+---------------+-------+
| Variable_name | Value |
+---------------+-------+
| wait_timeout  | 10    | 
+---------------+-------+


4) 會話變量和全局變量轉換方法: 在命令行裏通過SET來設置
將會話變量值設置爲對應的全局變量值呢:
mysql> set @@session.wait_timeout=@@global.wait_timeout;
將會話變量值設置爲MySQL編譯時的默認值(wait_timeout=28800):
mysql> set wait_timeout=DEFAULT;
這裏要注意的是, 並不是所有的系統變量都能被設置爲DEFAULT, 如果設置這些變量爲DEFAULT則會返回錯誤. 
--End-
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章