MySQL查看最大連接數(shù)和修改最大連接數(shù)
1、查看最大連接數(shù)
show variables like '%max_connections%';
2、修改最大連接數(shù)
set GLOBAL max_connections = 200;
以下的文章主要是向大家介紹的是MySQL最大連接數(shù)的修改,我們大家都知道MySQL最大連接數(shù)的默認值是100, 這個數(shù)值對于并發(fā)連接很多的數(shù)據(jù)庫的應用是遠不夠用的,當連接請求大于默認連接數(shù)后,就會出現(xiàn)無法連接數(shù)據(jù)庫的錯誤,因此我們需要把它適當調(diào)大一些。在使 用MySQL數(shù)據(jù)庫的時候,經(jīng)常會遇到這么一個問題,就是“Can not connect to MySQL server. Too many connections”-mysql 1040
錯誤,這是因為訪問MySQL且還未釋放的連接數(shù)目已經(jīng)達到MySQL的上限。通常,mysql的最大連接數(shù)默認是100, 最大可以達到16384。
mysql數(shù)據(jù)庫連接數(shù)過多導致系統(tǒng)出錯,系統(tǒng)不能連接數(shù)據(jù)庫,關鍵要看兩個數(shù)據(jù):
1、數(shù)據(jù)庫系統(tǒng)允許的最大可連接數(shù)max_connections
。這個參數(shù)是可以設置的。如果不設置,默認是100。
2、數(shù)據(jù)庫當前的連接線程數(shù)threads_connected
。這是動態(tài)變化的。
查看max_connections、max_connections的辦法下面我們再說。
如果 threads_connected == max_connections
時,數(shù)據(jù)庫系統(tǒng)就不能提供更多的連接數(shù)了,這時,如果程序還想新建連接線程,數(shù)據(jù)庫系統(tǒng)就會拒絕,如果程序沒做太多的錯誤處理。
因為創(chuàng)建和銷毀數(shù)據(jù)庫的連接,都會消耗系統(tǒng)的資源。而且為了避免在同一時間同時打開過多的連接線程,現(xiàn)在編程一般都使用所謂數(shù)據(jù)庫連接池技術。
但數(shù)據(jù)庫連接池技術,并不能避免程序錯誤導致連接資源消耗殆盡。
這種情況通常發(fā)生在程序未能及時釋放數(shù)據(jù)庫連接資源或其他原因造成數(shù)據(jù)庫連接資源不能釋放,發(fā)生類似錯誤的簡便的檢查辦法是,在刷新頁面時,不斷監(jiān)視threads_connected的變化。如果max_connections足夠大,而 threads_connected值不斷增加以至達到max_connections,那么,就應該檢查程序了。當然,如果采用數(shù)據(jù)庫連接池技術,threads_connected增長到數(shù)據(jù)庫連接池的最大連接線程數(shù)時,就不再增長了。
查看 max_connections
show variables like "max_connections";
結果如下:
+-----------------+-------+
| Variable_name | Value |
+-----------------+-------+
| max_connections | 100 |
+-----------------+-------+
查看 threads_connected
show status like 'Thread_%';
結果如下:
+-------------------+-------+
| Variable_name | Value |
+-------------------+-------+
| Threads_cached | 0 |
| Threads_connected | 1 |
| Threads_created | 1 |
| Threads_running | 1 |
+-------------------+-------+
設置max_connections
設置辦法是在my.cnf
文件中找到max_connections
一項修改即可,若沒有該項,請在[mysqld]下添加一行:
[mysqld]
max_connections=1000
修改完畢后,重啟MySQL即可。當然,為了確保設置正確,應該查看一下max_connections。
注意:
- 1、這里寫的1000。請按實際要求修改;
- 2、添加了最大允許連接數(shù),對系統(tǒng)消耗增加不大。
- 3、如果你的mysql用的是my.ini作配置文件,設置類似,但設置的格式要稍作變通。
其他需注意的:
在編程時,由于用MySQL語句調(diào)用數(shù)據(jù)庫時,在每次之執(zhí)行語句前,會做一個臨時的變量用來打開數(shù)據(jù)庫,所以你在使用MySQL語句的時候,記得在每次調(diào)用完MySQL之后就關閉MySQL臨時變量。
另外對于訪問量大的,可以考慮直接寫到文本中,根據(jù)預測的訪問量,先定義假若是100個文件文件名,需要的時候,再對所有文本文件中的數(shù)據(jù)進行分析,再導入數(shù)據(jù)庫。
總結
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對腳本之家的支持。如果你想了解更多相關內(nèi)容請查看下面相關鏈接
您可能感興趣的文章:- 總結MySQL修改最大連接數(shù)的兩個方式
- mysql最大連接數(shù)設置技巧總結
- 如何增加mysql的最大連接數(shù)
- 修改MYSQL最大連接數(shù)的3種方法分享
- docker中修改mysql最大連接數(shù)及配置文件的實現(xiàn)
- MySQL正確修改最大連接數(shù)的3種方案