解決mysql報錯:Data?source?rejected?establishment?of?connection,?message?from?server:?\"Too?many?connectio
最近在做壓力測試嘛,需要逐步增加用戶量做驗證,每個用戶單獨創(chuàng)建數(shù)據(jù)庫進行連接,就要不斷去創(chuàng)建數(shù)據(jù)庫,這個報錯也很容易理解,mysql連接數(shù)不夠用了
報錯
報錯信息如下:
"SQLState":"08004","vendorCode":1040,"detailMessage":
"Data source rejected establishment of connection,message from server: \"Too many connections\""
原因
根本原因是mysql連接數(shù)不夠用了
但也要分情況看為什么不夠用了
1.是mysql的max_connections屬性配置太小?
2.還是是多次insert,update操作沒有關閉session?
如果你也不確定,就繼續(xù)往下看
解決
我們要知道,mysql版本的不同,可設置的最大連接數(shù)范圍也是有所區(qū)別的:
Mysql5.5~5.7:默認的最大連接數(shù)都是151,上限為:100000
Mysql5.0版本:默認的最大連接數(shù)為100,上限為16384
查看mysql版本
select version();
如下,我這里是基于mysql 5.7,那么默認的最大連接數(shù)應該是151
查看當前mysql最大連接數(shù)限制
show variables like 'max_connections';
當前最大連接數(shù)限制是151,說明沒有改過最大連接數(shù)限制
確定連接數(shù)不夠原因
如上所示,我的情況當前是最大連接數(shù)限制是151,在此之前依然創(chuàng)建過十幾個數(shù)據(jù)庫;同時我又再次自行檢查過,我這里不存在未關閉session的操作
所以原因是max_connections屬性配置太小
修改最大連接數(shù)
修改mysql客戶端最大連接數(shù)可以通過兩種方式:
一種是使用命令設置,另一種是直接修改my.cnf文件
命令設置
使用命令設置這種方式是臨時修改,只能治標不能治本,在這個mysql服務不重啟的條件下是可用的,若mysql重啟會恢復到mysql默認的連接數(shù)(或者恢復到my.cnf文件中配置的最大連接數(shù))。
但由于我是在測試,無所謂,mysql重啟后的連接數(shù)
set global max_connections=1500;
修改my.cnf文件
mysql重啟后會優(yōu)先使用my.cnf配置文件中的配置,用上面命令設置后,若重啟mysql服務,則還是會回到my.cnf文件中配置的最大連接數(shù)(或者默認值)。
# 修改my.cnf文件,在文件中加入如下屬性 max_connections=1500 # 然后重啟mysql服務 $ service mysqld restart
再次去創(chuàng)建數(shù)據(jù)庫連接,就沒問題了!
總結
到此這篇關于解決mysql報錯:Data source rejected establishment of connection, message from server: \"Too many connectio的文章就介紹到這了,更多相關mysql報錯連接數(shù)不夠用內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
MySql8 WITH RECURSIVE遞歸查詢父子集的方法
這篇文章主要介紹了MySql8 WITH RECURSIVE遞歸查詢父子集的方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2020-12-12