mysql優化 連線數

2021-09-06 18:43:31 字數 2356 閱讀 5094

有時候我們會遇見」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...