有時候我們會遇見」mysql: error 1040: too many connections」的異常,一種原因是訪問量過高,mysqlserver抗不住,這個時候就要考慮新增從server分散讀壓力,還有一種原因就是mysql配置檔案裡max_connections值過小。
首先,我們來檢視mysql的最大連線數:
mysql> show variables like '%max_connections%';
+-----------------+-------+
| variable_name | value |
+-----------------+-------+
| max_connections | 151 |
+-----------------+-------+
1 row in set (0.00 sec)
其次,檢視server響應的最大連線數:
mysql> show global status like 'max_used_connections';
+----------------------+-------+
| variable_name | value |
+----------------------+-------+
| max_used_connections | 2 |
+----------------------+-------+
1 row in set (0.00 sec)
能夠看到server響應的最大連線數為2,遠遠低於mysqlserver同意的最大連線數值。
對於mysqlserver最大連線數值的設定範圍比較理想的是:server響應的最大連線數值佔server上限連線數值的比例值在10%以上,假設在10%下面,說明mysqlserver最大連線上限值設定過高。
max_used_connections / max_connections * 100% = 2/151 *100% ≈ 1%
我們能夠看到佔比遠低於10%(由於這是本地測試server,結果值沒有太大的參考意義,大家能夠依據實際情況設定連線數的上限值)。
mysql> show variables like '%max_connections%';
+-----------------+-------+
| variable_name | value |
+-----------------+-------+
| max_connections | 151 |
+-----------------+-------+
1 row in set (0.19 sec)
mysql> show global status like 'max_used_connections';
+----------------------+-------+
| variable_name | value |
+----------------------+-------+
| max_used_connections | 44 |
+----------------------+-------+
1 row in set (0.17 sec)
這裡的最大連線數佔上限連線數的30%左右。
上面我們知道怎麼檢視mysqlserver的最大連線數值,而且知道了怎樣推斷該值是否合理,以下我們就來介紹一下怎樣設定這個最大連線數值。
方法1:
mysql> set global max_connections=256;
query ok, 0 rows affected (0.00 sec)
mysql> show variables like '%max_connections%';
+-----------------+-------+
| variable_name | value |
+-----------------+-------+
| max_connections | 256 |
+-----------------+-------+
1 row in set (0.00 sec)
方法2:
改動mysql配置檔案my.cnf,在[mysqld]段中加入或改動max_connections值:
max_connections=128
重新啟動mysql服務就可以。
mysql優化 連線數
有時候我們會遇見 mysql error 1040 too many connections 的異常。一種原因是訪問量過高,mysqlserver抗不住。這個時候就要考慮新增從server分散讀壓力。還有一種原因就是mysql配置檔案裡max connections值過小。首先。我們來檢視mysql...
Apache 連線數優化
可見的mpm配置在 usr local httpd conf extra httpd mpm.conf 當前httpd的工作模式檢視 mod so.c有prefork,故當前httpd應該是工作在prefork模式.prefork模式的預設配置是 startservers 5 minspareser...
mysql 太多的連線數 mysql 連線數太多
問題記錄 mysql error 1040 too many connections 解決辦法 1.檢視mysql的最大連線數 mysql show variables like max connections 500 2.檢視伺服器響應的最大連線數 mysql show global status...