[精讚] [會員登入]
1466

[Mysql/MariaDB] 清除及設定 MySQL 的死連接

mysql 伺服器若有太多的連接,無疑的會耗用非常多的資源,若資源耗盡會影響新的連線,勢必要做一些調整

此文完整連結 http://n.sfs.tw/10657

複製連結 [Mysql/MariaDB] 清除及設定 MySQL 的死連接@新精讚
(文章歡迎轉載,務必尊重版權註明連結來源)
2017-01-23 01:44:43 最後編修
2017-01-23 01:44:43 By 瘦河馬
 

mysql 伺服器的連線的會耗用資源,例如連線數、頻寬、記憶體、cpu等。如果遇到類似惡意的阻斷式DOS/DDOS的攻擊,一下吃下太多的連線,瞬間就會使伺服器異常。

這時除了重啟以外,還有沒有別的招?

查看目前的連線

使用 show processlist 來查看目前的連線,可以查看出效能的瓶頸。

mysql> SHOW PROCESSLIST;
+-------+------+-----------------+------+---------+------+-------+------------------+
| Id    | User | Host            | db   | Command | Time | State | Info             |
+-------+------+-----------------+------+---------+------+-------+------------------+
| 14850 | axer | localhost       | NULL | Query   |    0 | NULL  | SHOW PROCESSLIST |
| 14852 | note | localhost:62258 | note | Sleep   |    0 |       | NULL             |
+-------+------+-----------------+------+---------+------+-------+------------------+
2 rows in set (0.00 sec)

若連線的方式使用 persistent 方式,操作結束時不會立刻斷連,而會進入 Sleep 狀態

其中 Sleep 就是作完動作尚未 timeout 的連線,這時另一個欄位 Time 代表他 "sleep" 的時間,以上例而言為0 代表剛睡而已。如果要殺掉那個程序,就下指令

mysql> kill 14852;

查看及修改等待結束的時間

我們可以查看預設的連線時間,變數 wait_timeout:

mysql> show variables like '%timeout%';
+-----------------------------+----------+
| Variable_name               | Value    |
+-----------------------------+----------+
| connect_timeout             | 10       |
| delayed_insert_timeout      | 300      |
| innodb_flush_log_at_timeout | 1        |
| innodb_lock_wait_timeout    | 50       |
| innodb_rollback_on_timeout  | OFF      |
| interactive_timeout         | 28800    |
| lock_wait_timeout           | 31536000 |
| net_read_timeout            | 30       |
| net_write_timeout           | 60       |
| rpl_stop_slave_timeout      | 31536000 |
| slave_net_timeout           | 3600     |
| wait_timeout                | 28800    |
+-----------------------------+----------+
12 rows in set (0.00 sec)

 

預設是 28800 秒,真是驚人,那表示如果你的存取方式是permanent的連線狀態,一旦建立完沒有手動結束的話,他會一直睡到28800秒才會關閉,也就是約8個小時。這個值不要設太小,否則遇到比較耗時的查詢,還來不及查完就出現MySQL has gone away的錯誤。

依我的經驗180秒很足夠

執行期修改,設定為180秒

mysql> set wait_timeout=180;

永久設定

修改 /etc/my.cnf

[mysqld]
wait_timeout=180

重啟後生效


原文 2010-03-17 00:31:07

你可能感興趣的文章

Mysql 安裝完畢要做的事 Mysql 安裝完畢後,該處理的流程

[Mysql] Mysqldump 的預設編碼 --default-character-set 有時Mysqldump 也得要指定編碼才不會造成匯出的亂碼

[MYSQL] 把SELECT的結果UPDATE到表中 Mysql update select 出來的結果,一次完成

[MySQL/Mariadb] 正規表達式(regular express) mysql的正規表達式很詭異,很不能接受

[MariaDB] Centos 7安裝mariadb + apache + php + phpmyadmin Centos 7安裝mariadb+apache+php+phpmyadmin

[Mysql] 建立叢集式資料庫4/4--觀察及測試 觀察及測試haproxy+galera建立Mysql的叢集式資料庫,並進行壓力測試

[Mysql] 資料型態int, float, double, text, char, varchar, blob大小 Mysql中資料型態int, float, text, char, varchar, blob大小

[Mysql/MariaDB] 加解密函數 Mysql/MariaDB上的加解密函數

[Mysql] Trigger 觸發使用方法 trigger 在資料庫的使用上,具有極大的方便性,該如何使用?

兩次使用InnoDB的慘痛經驗 Mysql 的Innodb引擎雖然好用,但是我得說說我兩次的慘痛經驗,這讓我考慮以後可能不會再使用innodb了

我有話要說


限制:留言最高字數1000字,超過部分會被截掉。 限制:未登入訪客,每則留言間隔需超過10分鐘,每日最多5則留言。

訪客留言

[無留言]

隨機好文

[Freebsd] 使用 ADSL 撥接上網 Freebsd上要使用 ADSL 撥接上網,該如何設定?

安裝SPHINX支援中文 新版本的 sphinx 和舊版不同,網路上很多範例和教學是不能用的。此文是安裝和設定方法分享

[CodeIgniter3] 解決無法上傳特定檔案(.sb2)的問題 上傳時出現The filetype you are attempting to upload is not allowed,要怎麼解決?

Smarty安裝 smarty 是著名的樣版引擎,非常的好用,用多了突然發現拿掉smarty反而不會寫php了,以下是安裝過程..

[PHP] 檢查檔案是否是圖檔 使用getimagesize函數檢查檔案是否是圖檔