首頁 資料庫 mysql教程 mysql数据库连接过多的错误_MySQL

mysql数据库连接过多的错误_MySQL

Jun 01, 2016 pm 01:54 PM
資料庫連線 連接資料庫

统不能连接数据库,关键要看两个数据:
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作配置文件,设置类似,但设置的格式要稍作变通

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

熱門話題

Java教學
1664
14
CakePHP 教程
1423
52
Laravel 教程
1317
25
PHP教程
1268
29
C# 教程
1246
24
如何在FastAPI中實現資料庫連線與事務處理 如何在FastAPI中實現資料庫連線與事務處理 Jul 30, 2023 am 11:45 AM

如何在FastAPI中實現資料庫連接和事務處理引言:隨著Web應用程式的快速發展,資料庫連接和事務處理成為了一個非常重要的主題。 FastAPI是一個高效能的PythonWeb框架,因其快速且易於使用而受到開發者的喜愛。在本文中,我們將介紹如何在FastAPI中實現資料庫連接和事務處理,以協助您建立可靠且高效的網路應用程式。第一部分:資料庫連線在FastA

如何使用PHP資料庫連線實現分頁查詢 如何使用PHP資料庫連線實現分頁查詢 Sep 08, 2023 pm 02:28 PM

如何使用PHP資料庫連線實現分頁查詢在開發web應用程式中,常常會涉及到對資料庫進行查詢並進行分頁顯示的需求。 PHP作為一種常用的服務端腳本語言,具備強大的資料庫連線功能,可以輕鬆實現分頁查詢。本文將詳細介紹如何使用PHP資料庫連線實作分頁查詢,並附上對應的程式碼範例。準備資料庫在開始之前,我們需要準備一個資料庫,包含要查詢的資料。這裡以MySQL資料庫為例,

4050顯示卡適合玩哪些遊戲 4050顯示卡適合玩哪些遊戲 Jan 06, 2024 pm 05:01 PM

對於nvidia的遊戲顯示卡來說,最重要的一點就是它能帶的動哪些遊戲了,所以想要購買4050顯示卡的朋友自然也好奇這款顯示卡能玩哪些遊戲呢,其實它應該能玩所有遊戲了。 4050顯示卡能帶的動哪些遊戲:答:4050顯示卡應該能帶得動市面上所有電腦遊戲。它的表現至少能和現在的3060ti相比,而3060ti就能帶動現在的所有pc遊戲了。 (以下我們從3060ti的測試來預測4050的表現)1、在遊戲測試方面,3060ti在1080p解析度下能維持在穩定150fps以上。 2、因此我們直接測試它在2k解析度下的表現。

C#中常見的資料庫連線和資料讀寫問題 C#中常見的資料庫連線和資料讀寫問題 Oct 10, 2023 pm 07:24 PM

C#中常見的資料庫連線和資料讀寫問題,需要具體程式碼範例在C#開發中,資料庫連線和資料讀寫是經常遇到的問題,正確處理這些問題是保證程式碼品質和效能的關鍵。本文將介紹一些常見的資料庫連接和資料讀寫問題,並提供具體的程式碼範例,幫助讀者更好地理解和解決這些問題。資料庫連線問題1.1連接字串錯誤在連接資料庫時,常見的錯誤是連接字串不正確。連接字串包含了連接資料庫

進階 PHP 資料庫連線:交易、鎖和並發控制 進階 PHP 資料庫連線:交易、鎖和並發控制 Jun 01, 2024 am 11:43 AM

高階PHP資料庫連線涉及交易、鎖和並發控制,以確保資料完整性和避免錯誤。事務是一組操作的原子單元,透過beginTransaction()、commit()和rollback()方法管理。鎖透過PDO::LOCK_SHARED和PDO::LOCK_EXCLUSIVE防止同時存取資料。並發控制透過MySQL隔離等級(讀未提交、讀取已提交、可重複讀取、串列化)協調多個交易的存取。實際應用中,事務、鎖和並發控制用於購物網站的產品庫存管理,確保資料完整性和避免庫存問題。

如何連接和操作資料庫以及處理SQL查詢 如何連接和操作資料庫以及處理SQL查詢 Aug 02, 2023 am 09:06 AM

如何連接和操作資料庫以及處理SQL查詢在開發應用程式的過程中,資料庫連接和操作是非常重要的一部分。資料庫是儲存和管理資料的重要工具,而SQL(StructuredQueryLanguage)是用於查詢和操作資料庫的標準語言。在本文中,我們將學習如何連接和操作資料庫,並展示一些處理SQL查詢的程式碼範例。連接資料庫:首先,我們需要連接到資料庫才能進行

為什麼我的 PHP 資料庫連線失敗? 為什麼我的 PHP 資料庫連線失敗? Jun 05, 2024 pm 07:55 PM

PHP資料庫連線失敗的原因有:資料庫伺服器未運作、主機名稱或連接埠不正確、資料庫憑證不正確、缺少適當的權限。解決方法包括:啟動伺服器、檢查主機名稱和連接埠、核對憑證、修改權限和調整防火牆設定。

mybatis如何設定資料庫連接 mybatis如何設定資料庫連接 Jan 15, 2024 pm 02:12 PM

mybatis設定資料庫連線的方法:1、指定資料來源;2、設定事務管理器;3、設定類型處理器和映射器;4、使用環境元素;5、設定別名。詳細介紹:1、指定資料來源,在「mybatis-config.xml」檔案中,需要設定資料來源,資料來源是一個接口,它提供了資料庫連線;2、設定事務管理器,為了確保資料庫事務的正常處理,還需要配置事務管理器;3、配置類型處理器和映射器等等。

See all articles