首先要了解為什麼用連接池,連接池能為你解決什麼問題
連接池主要的作用:
1、減少與資料伺服器建立TCP連線三次握手及連線關閉四次揮手的開銷,從而降低客戶端和mysql服務端的負載,縮短請求回應時間
2、減少資料庫的並發連線數,即解決應用伺服器過多導致的資料庫too many connections 問題
如果是為了解決問題1
則在workerman中資料庫連線池不是最有效率的方法,反而是自找麻煩的做法。由於PHP是單進程單線程的,使用PHP實現資料庫連接池,所以肯定需要用單獨的進程去做,那麼就會涉及到進程間的通訊,使得原本和mysql直接通訊的過程變成與連接池再到mysql的通訊,增加了應用端的負載。
解決問題1最有效率的方法是為每個業務進程建立一個資料庫單例(例如workerman提供的DB類別),實現資料庫長連接,這樣每個進程的所有請求都使用自己的這一個資料庫長連接,整個進程的生命週期只有一次TCP握手和斷開連接揮手的開銷,並且應用與mysql直接通訊,沒有連接池那樣中間一層進程間IPC通訊,性能是最高的,沒有之一。
如果是為了問題2
首先看下自己到底有多少應用伺服器,每台伺服器與mysql有多收並發連線。假如你只有10台應用伺服器,每個伺服器50個進程,每個進程1個資料庫連接,那麼到mysql服務端總共只有10*50=500個並發連接(並非活躍連接),500個並發連接對於mysql來說就是小菜一碟,為了解決問題2完全沒有使用連接池的必要。
假如你有1000台應用伺服器,那麼連接池是有必要的,但是這個連接池不能是運行在本地應用伺服器上的連接池,因為1000台應用伺服器就有1000個連接池,即使每個連接池只開10個連接,那麼資料庫的連線數也會輕鬆打滿。所以不要指望在目前伺服器上開幾個task進程實現的連線池就能解決這個問題。
1000台應用程式伺服器的集群,每台伺服器上搞幾個進程實現連接池同樣是不靠譜的方法。真正能夠解決問題2的方法是建立一個獨立的資料庫連接池伺服器或說集群,全域管理所有的資料庫連結。
綜上所述,
如果單獨是為了問題1實作php的mysql連線池,那麼資料庫單例是比所謂的連線池更簡單更有效率的做法。
如果是為了實現問題2,那麼想必業務也有一定的規模了,如果真心是想用workerman做個單獨的連接池集群,下面是大概簡單的做法,建立一些task進程,每個進程創建一個資料庫連接,task進程收到sql請求後發送給mysql伺服器,mysql伺服器返回後task進程再把結果發給sql發起者。
連接池代碼類似如下如果是多台伺服器組成的連接池集群,前面最好加一個lvs:
// task worker,使用Text协议 $task_worker = new Worker('Text://0.0.0.0:1234'); $task_worker->count = 64; $task_worker->name = 'MysqlTask'; $task_worker->onMessage = function($connection, $sql) { // 执行sql.... 得到结果,这里省略.... $sql_result = your_mysql_query($sql); // 发送结果 $connection->send(json_encode($sql_result)); };
在workerman中調用:
use \Workerman\Connection\AsyncTcpConnection; // 与远程连接池服务建立异步链接,ip为远程连接池服务的ip,如果是集群就是lvs的ip $sql_connection = new AsyncTcpConnection('Text://ip:1234'); // 发送sql $sql_connection->send("SELECT ... FROM ....."); // 异步获得sql结果 $sql_connection->onMessage = function($sql_connection, $sql_result) { // 这里只是打印结果 var_dump(json_decode($task_result)); }; // 执行异步链接 $sql_connection->connect();
更多workerman知識請關注PHP中文網workerman教學專欄。
以上是workerman寫mysql連結池的方法與作用的詳細內容。更多資訊請關注PHP中文網其他相關文章!

Workerman的Websocket客戶端可以通過異步通信,高性能,可伸縮性和安全性等功能增強實時通信,並可以輕鬆地與現有系統集成。

本文討論了使用高性能PHP服務器Workerman來構建實時協作工具。它涵蓋安裝,服務器設置,實時功能實現以及與現有系統集成,強調Workerman的密鑰F

本文討論了針對低延遲應用程序的優化工作人員,重點介紹異步編程,網絡配置,資源管理,數據傳輸最小化,負載平衡和常規更新。

本文討論了使用Workerman和MySQL實施實時數據同步的,重點是設置,最佳實踐,確保數據一致性以及解決共同挑戰。

本文討論了將工作人員集成到無服務器體系結構中,專注於可擴展性,無狀態,冷啟動,資源管理和集成複雜性。 Workerman通過高並發,降低冷STA來提高性能

文章討論了使用Workerman建立高性能的電子商務平台,重點關注其功能,例如Websocket支持和可擴展性,以提高實時交互和效率。

Workerman的Websocket服務器可以通過可擴展性,低延遲和針對常見威脅的安全措施等功能增強實時通信。

本文討論了使用高性能PHP服務器Workerman來構建實時分析儀表板。它涵蓋了與React,vue.js和Angular等框架的安裝,服務器設置,數據處理以及前端集成。關鍵功能


熱AI工具

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

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

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SecLists
SecLists是最終安全測試人員的伙伴。它是一個包含各種類型清單的集合,這些清單在安全評估過程中經常使用,而且都在一個地方。 SecLists透過方便地提供安全測試人員可能需要的所有列表,幫助提高安全測試的效率和生產力。清單類型包括使用者名稱、密碼、URL、模糊測試有效載荷、敏感資料模式、Web shell等等。測試人員只需將此儲存庫拉到新的測試機上,他就可以存取所需的每種類型的清單。

禪工作室 13.0.1
強大的PHP整合開發環境

DVWA
Damn Vulnerable Web App (DVWA) 是一個PHP/MySQL的Web應用程序,非常容易受到攻擊。它的主要目標是成為安全專業人員在合法環境中測試自己的技能和工具的輔助工具,幫助Web開發人員更好地理解保護網路應用程式的過程,並幫助教師/學生在課堂環境中教授/學習Web應用程式安全性。 DVWA的目標是透過簡單直接的介面練習一些最常見的Web漏洞,難度各不相同。請注意,該軟體中

ZendStudio 13.5.1 Mac
強大的PHP整合開發環境