mysql如何實(shí)現(xiàn)最大連接數(shù)
數(shù)據(jù)庫連接數(shù)突然增大是什么原因?
可能是數(shù)據(jù)庫性能突然變慢,連接的客戶要很久才能得到響應(yīng),客戶以為是自己沒確認(rèn)到,于是客戶就不斷地連接,這樣會(huì)話就增加了,數(shù)據(jù)庫就更忙了,最后可能會(huì)掛了。
一、前言
? ? ?項(xiàng)目中可能會(huì)遇到MySQL: ERROR 1040: Too many connections”的異常情況;Why:造成這種情況的一種原因是訪問量過高,MySQL服務(wù)器抗不住,這個(gè)時(shí)候就要考慮增加從服務(wù)器分散讀壓力;另一種原因就是MySQL配置文件中max_connections值過小。
二、知識(shí)點(diǎn)
? ? ?Mysql的max_connections參數(shù)用來設(shè)置最大連接(用戶)數(shù)。每個(gè)連接MYSQL的用戶均算作一個(gè)連接,max_connections的默認(rèn)值不同版本略有區(qū)別。
Mysql5.5?mysql5.6 ?mysql5.7:默認(rèn)的最大連接數(shù)都是151,上限為:100000

Mysql5.1根據(jù)其小版本的不同,默認(rèn)的最大連接數(shù)和可修改的連接數(shù)上限也有所不同

Mysql5.0版本:默認(rèn)的最大連接數(shù)為100,上限為16384

? ? ?吐槽一下mysql版本的命名,從5.7一下跳到8.0版本。Mysql5.5?mysql5.6 ?mysql5.7:默認(rèn)的最大連接數(shù)都是151。這個(gè)數(shù)值對(duì)于并發(fā)連接很多的數(shù)據(jù)庫應(yīng)用是遠(yuǎn)不夠用的。當(dāng)連接請(qǐng)求大于默認(rèn)連接數(shù)后,就會(huì)出現(xiàn)無法連接數(shù)據(jù)庫的錯(cuò)誤,因此我們需要把它適當(dāng)調(diào)大一些。在使用 MySQL 數(shù)據(jù)庫的時(shí)候,經(jīng)常會(huì)遇到一個(gè)問題,就是”Can not connect to MySQL server. Too many connections” -mysql 1040 錯(cuò)誤,這是因?yàn)樵L問MySQL且還未釋放的連接數(shù)已經(jīng)達(dá)到 MySQL 的上限。MySQL無論如何都會(huì)保留一個(gè)用于管理員(SUPER)登陸的連接,用于管理員連接數(shù)據(jù)庫進(jìn)行維護(hù)操作,即使當(dāng)前連接數(shù)已經(jīng)達(dá)到了max_connections。因此MySQL的實(shí)際最大可連接數(shù)為max_connections+1;增加max_connections參數(shù)的值,不會(huì)占用太多系統(tǒng)資源。系統(tǒng)資源(CPU、內(nèi)存)的占用主要取決于查詢的密度、效率等;該參數(shù)設(shè)置過小的最明顯特征是出現(xiàn)”Too many connections”錯(cuò)誤;
三、實(shí)操
1、查看最大連接數(shù)
Mysql5.5?mysql5.6 ?mysql5.7:默認(rèn)的最大連接數(shù)都是151,上限為:100000
mysql> show variables like "%max_connections%";
±----------------±------+
| Variable_name | Value|
±----------------±------+
| max_connections| 151 |
±----------------±------+
1 row in set (0.00 sec)
2、查看服務(wù)器響應(yīng)的最大連接數(shù)
mysql> show global status like 'Max_used_connections'; +----------------------+-------+ | Variable_name | Value | +----------------------+-------+ | Max_used_connections | 11 | +----------------------+-------+ 1 row in set (0.00 sec)
可以看到服務(wù)器響應(yīng)的最大連接數(shù)為11,遠(yuǎn)遠(yuǎn)低于mysql服務(wù)器允許的最大連接數(shù)值。對(duì)于mysql服務(wù)器最大連接數(shù)值的設(shè)置范圍比較理想的是:服務(wù)器響應(yīng)的最大連接數(shù)值占服務(wù)器上限連接數(shù)值的比例值在10%以上,如果在10%以下,說明mysql服務(wù)器最大連接上限值設(shè)置過高。
3、修改最大連接數(shù)
常用的修改最大連接數(shù)的兩種方式如下:
第一種:命令行修改最大連接數(shù)(max_connections),設(shè)置最大連接數(shù)為1000。
mysql> set global max_connections = 1000;
這種方式有個(gè)問題,就是設(shè)置的最大連接數(shù)只在 MySQL 當(dāng)前服務(wù)進(jìn)程有效,一旦MySQL重啟,又會(huì)恢復(fù)到初始狀態(tài)。因?yàn)镸ySQL啟動(dòng)后的初始化工作是從其配置文件中讀取數(shù)據(jù)的,而這種方式?jīng)]有對(duì)其配置文件做更改。
第二種:通過修改配置文件來修改MySQL最大連接數(shù)(max_connections)。
進(jìn)入MySQL安裝目錄,打開MySQL配置文件 my.ini 或 my.cnf查找 max_connections=100,修改為max_connections=1000,重啟MySQL服務(wù)即可。
四、參考資料
1、https://www.yisu.com/zixun/38410.html
2、https://bbs.huaweicloud.com/blogs/147608
到此這篇關(guān)于mysql如何實(shí)現(xiàn)最大連接數(shù)的文章就介紹到這了,更多相關(guān)mysql 最大連接數(shù)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Mysql 5.5.56版本(二進(jìn)制包安裝)自定義安裝路徑步驟記錄
這篇文章主要介紹了Mysql 5.5.56版本(二進(jìn)制包安裝)自定義安裝路徑步驟記錄,需要的朋友可以參考下2017-07-07
MySQL版本低了不支持兩個(gè)時(shí)間戳類型的值解決方法
在本篇文章里小編給大家分享了關(guān)于MySQL 版本低了,不支持兩個(gè)時(shí)間戳類型的值的相關(guān)知識(shí)點(diǎn),有興趣的朋友們可以參考下。2019-09-09
MySQL數(shù)據(jù)庫?觸發(fā)器?trigger
這篇文章主要介紹了MySQL數(shù)據(jù)庫?觸發(fā)器?trigger,觸發(fā)器是一種特殊類型的存儲(chǔ)過程,觸發(fā)器通過事件進(jìn)行觸發(fā)而被執(zhí)行,可通過數(shù)據(jù)庫中的相關(guān)表實(shí)現(xiàn)級(jí)聯(lián)更改,保證數(shù)據(jù)安全,進(jìn)行安全校驗(yàn)2022-06-06
MySQL如何對(duì)數(shù)據(jù)進(jìn)行排序圖文詳解
我們知道從MySQL表中使用SQL SELECT語句來讀取數(shù)據(jù),下面這篇文章主要給大家介紹了關(guān)于MySQL如何對(duì)數(shù)據(jù)進(jìn)行排序的相關(guān)資料,文中通過圖文介紹的非常詳細(xì),需要的朋友可以參考下2022-08-08
mysql生成指定位數(shù)的隨機(jī)數(shù)及批量生成隨機(jī)數(shù)的方法
這篇文章主要介紹了mysql生成指定位數(shù)的隨機(jī)數(shù)及批量生成隨機(jī)數(shù)的方法,文中給大家介紹了常用mysql函數(shù),需要的朋友可以參考下2018-09-09
mysql存儲(chǔ)過程如何利用臨時(shí)表返回結(jié)果集
這篇文章主要介紹了mysql存儲(chǔ)過程如何利用臨時(shí)表返回結(jié)果集,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-09-09
MySQL數(shù)據(jù)更新操作的兩種辦法(數(shù)據(jù)可視化工具和SQL語句)
MySQL是最常用的數(shù)據(jù)庫,在數(shù)據(jù)庫操作中,基本都是增刪改查操作,簡稱CRUD,下面這篇文章主要給大家介紹了關(guān)于MySQL數(shù)據(jù)更新操作的兩種辦法,需要的朋友可以參考下2023-03-03

