輕鬆解決MYSQL資料庫連接過多的錯誤

来源:http://www.cnblogs.com/aspnetjia/archive/2016/02/12/5186991.html
-Advertisement-
Play Games

1、資料庫系統允許的最大可連接數max_connections。這個參數是可以設置的。如果不設置,預設是100。最大是16384。 2、資料庫當前的連接線程數threads_connected。這是動態變化的。 查看max_connections、max_connections的辦法見後。 如果 t


1、資料庫系統允許的最大可連接數max_connections。這個參數是可以設置的。如果不設置,預設是100。最大是16384。

2、資料庫當前的連接線程數threads_connected。這是動態變化的。

查看max_connections、max_connections的辦法見後。

如果 threads_connected == max_connections 時,資料庫系統就不能提供更多的連接數了,這時,如果程式還想新建連接線程,資料庫系統就會拒絕,如果程式沒做太多的錯誤處理,就會出現類似強壇的報錯信息。

因為創建和銷毀資料庫的連接,都會消耗系統的資源。而且為了避免在同一時間同時打開過多的連接線程,現在編程一般都使用所謂資料庫連接池技術。

但資料庫連接池技術,並不能避免程式錯誤導致連接資源消耗殆盡。

這種情況通常發生在程式未能及時釋放資料庫連接資源或其他原因造成資料庫連接資源不能釋放,但強壇系統估計不會發生這種低級的編程錯誤。

該錯誤的簡便的檢查辦法是,在刷新強壇頁面時,不斷監視threads_connected的變化。如果max_connections足夠大,而 threads_connected值不斷增加以至達到max_connections,那麼,就應該檢查程式了。當然,如果採用資料庫連接池技術, threads_connected增長到資料庫連接池的最大連接線程數時,就不再增長了。

從強壇出錯的情況看,更大的可能性是資料庫系統沒能進行適當地配置。下麵提出一點建議。供參考

讓你們的工程師把MySQL的最大允許連接數從預設的100調成32000。這就不會老出現連接過多的問題了。

查看max_connections

進入MySQL,用命令:

show variables

查看資料庫最大可連接數的變數值:

max_connections

查看threads_connected

進入MySQL,用命令:

show status

查看當前活動的連接線程變數值:

threads_connected

設置max_connections

設置辦法是在my.cnf文件中,添加下麵的最後紅色的一行:

[mysqld] 
port=3306 
#socket=MySQL 
skip-locking 
set-variable = key_buffer=16K 
set-variable = max_allowed_packet=1M 
set-variable = thread_stack=64K 
set-variable = table_cache=4 
set-variable = sort_buffer=64K 
set-variable = net_buffer_length=2K 
set-variable = max_connections=32000

修改完畢後,重啟MySQL即可。當然,為了確保設置正確,應該查看一下max_connections。

註意:

1、雖然這裡寫的32000。但實際MySQL伺服器允許的最大連接數16384;

2、除max_connections外,上述其他配置應該根據你們系統自身需要進行配置,不必拘泥;

3、添加了最大允許連接數,對系統消耗增加不大。

4、如果你的mysql用的是my.ini作配置文件,設置類似,但設置的格式要稍作變通

 轉賬自:http://www.aspnetjia.com


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 自定義tabbar高度的跳轉隱藏問題 === 問題並不是很複雜,只是需求特殊,在網上沒有找到類似的demo,網上也有很多blog或者技術文章都有自己的見解,還沒有找到能完的解決我的需求的方法,這個問題從年前一直想到年後,想了大概一禮拜吧。。。終於解決!!! 在網上也找到很多大神的博客,辯論自定義ta
  • 前言: 首先展示一下這個iOS小示例的彩色進度條動畫效果: 閱讀本文先說說好處:對於基礎不好的讀者,可以直接閱讀文末尾的"如何使用彩虹動畫進度條"章節,然後將我封裝好的這個功能模塊類用到你的工程項目中即可。 這個效果的示例是老外Nick Jensen在2013年寫的一個作品:使用CAGradient
  • 字元串查找。在模糊朝找的情況下,其實3者的效率是差不多的。都需要一個一個取出來然後掃一遍╮(╯_╰)╭。然而用法還是會有一點兒的區別 1 charindex (查找的字元串,字元串表達式[,開始查找的位置]) ,簡單來說用法就是這樣紙。然而這個函數對 text,ntext,image 類型無效,並且
  • 現在網上絕大多數網站都是ACCESS+ASP的形式,因為ACCESS結構簡單容易處理,而且也能滿足多數的網站程式要求。 ACCESS是小型資料庫,既然是小型就有他根本的局限性,以下幾種情況下資料庫基本上會吃不消: 1。資料庫過大,一般ACCESS資料庫達到50M左右的時候性能會急劇下降! 2。網站訪
  • 1、delete:刪除數據表中的行(可以刪除某一行,也可以在不刪除數據表的情況下刪除所有行) 刪除某一行:delete from 數據表名稱 where 列名稱=值; 刪除所有行:delete*from 數據表名稱 2、drop:刪除數據表或資料庫或數據表欄位 刪除資料庫:drop database
  • 1、exists:sql返回結果集為真;not exists:sql不返回結果集為真。詳解過程如圖: exists not exists
  • 1、show warnings:顯示上一個語句的錯誤、警告以及註意。如圖:
  • 一般來說,轉換函數大家並不陌生。就是使用cast 和 convert 進行數據類型的轉換來達到表達式的比較,語句的拼接等效果。 使用倒是很容易的。一般情況下這樣使用就可以了。 SELECT CONVERT(INT,'123') SELECT CAST('123' AS INT) 還有一個比較少用的,
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...