小編給大家分享一下workerman寫MySQL連接池有什么用,希望大家閱讀完這篇文章之后都有所收獲,下面讓我們一起去探討吧!
成都創(chuàng)新互聯(lián)公司服務(wù)項目包括白朗網(wǎng)站建設(shè)、白朗網(wǎng)站制作、白朗網(wǎng)頁制作以及白朗網(wǎng)絡(luò)營銷策劃等。多年來,我們專注于互聯(lián)網(wǎng)行業(yè),利用自身積累的技術(shù)優(yōu)勢、行業(yè)經(jīng)驗、深度合作伙伴關(guān)系等,向廣大中小型企業(yè)、政府機構(gòu)等提供互聯(lián)網(wǎng)行業(yè)的解決方案,白朗網(wǎng)站推廣取得了明顯的社會效益與經(jīng)濟效益。目前,我們服務(wù)的客戶以成都為中心已經(jīng)輻射到白朗省份的部分城市,未來相信會繼續(xù)擴大服務(wù)區(qū)域并繼續(xù)獲得客戶的支持與信任!
連接池主要的作用:
1、減少與數(shù)據(jù)服務(wù)器建立TCP連接三次握手及連接關(guān)閉四次揮手的開銷,從而降低客戶端和mysql服務(wù)端的負載,縮短請求響應(yīng)時間
2、減少數(shù)據(jù)庫的并發(fā)連接數(shù),即解決應(yīng)用服務(wù)器過多導(dǎo)致的數(shù)據(jù)庫 too many connections 問題
如果是為了解決問題1
則在workerman中數(shù)據(jù)庫連接池不是最高效的方法,反而是自找麻煩的做法。由于PHP是單進程單線程的,使用PHP實現(xiàn)數(shù)據(jù)庫連接池,肯定需要用單獨的進程去做,那么就會涉及到進程間的通訊,使得原本和mysql直接通訊的過程變成 與連接池再到mysql的通訊,增加了應(yīng)用端的負載。
解決問題1最高效的方法是為每個業(yè)務(wù)進程建立一個數(shù)據(jù)庫單例(例如workerman提供的DB類),實現(xiàn)數(shù)據(jù)庫長連接,這樣每個進程的所有請求都使用自己的這一個數(shù)據(jù)庫長連接,整個進程的生命周期只有一次TCP握手和斷開連接揮手的開銷,并且應(yīng)用與mysql直接通訊,沒有連接池那樣中間一層進程間IPC通訊,性能是最高的,沒有之一。
如果是為了問題2
首先看下自己到底有多少臺應(yīng)用服務(wù)器,每臺服務(wù)器與mysql有多收并發(fā)連接。假如你只有10臺應(yīng)用服務(wù)器,每個服務(wù)器50個進程,每個進程1個數(shù)據(jù)庫連接,那么到mysql服務(wù)端總共只有10*50=500個并發(fā)連接(并非活躍連接),500個并發(fā)連接對于mysql來說就是小菜一碟,為了解決問題2完全沒有使用連接池的必要。
假如你有1000臺應(yīng)用服務(wù)器,那么連接池是有必要的,但是這個連接池不能是運行在本地應(yīng)用服務(wù)器上的連接池,因為1000臺應(yīng)用服務(wù)器就有1000個連接池,即使每個連接池只開10個連接,那么數(shù)據(jù)庫的連接數(shù)也會輕松打滿。所以不要指望在當前服務(wù)器上開幾個task進程實現(xiàn)的連接池就能解決這個問題。
1000臺應(yīng)用服務(wù)器的集群,每臺服務(wù)器上搞幾個進程實現(xiàn)連接池同樣是不靠譜的方法。真正能夠解決問題2的方法是建立一個獨立的數(shù)據(jù)庫連接池服務(wù)器或者說集群,全局管理所有的數(shù)據(jù)庫鏈接。
綜上所述,
如果單獨是為了問題1實現(xiàn)php的mysql連接池,那么數(shù)據(jù)庫單例是比所謂的連接池更簡單更高效的做法。
如果是為了實現(xiàn)問題2,那么想必業(yè)務(wù)也有一定的規(guī)模了,如果真心是想用workerman做個單獨的連接池集群,下面是大概簡單的做法,建立一些task進程,每個進程創(chuàng)建一個數(shù)據(jù)庫連接,task進程收到sql請求后發(fā)送給mysql服務(wù)器,mysql服務(wù)器返回后task進程再把結(jié)果發(fā)給sql發(fā)起者。
連接池代碼類似如下 如果是多臺服務(wù)器組成的連接池集群,前面最好加一個lvs:
// task worker,使用Text協(xié)議 $task_worker = new Worker('Text://0.0.0.0:1234'); $task_worker->count = 64; $task_worker->name = 'MysqlTask'; $task_worker->onMessage = function($connection, $sql) { // 執(zhí)行sql.... 得到結(jié)果,這里省略.... $sql_result = your_mysql_query($sql); // 發(fā)送結(jié)果 $connection->send(json_encode($sql_result)); };
在workerman中調(diào)用:
use \Workerman\Connection\AsyncTcpConnection; // 與遠程連接池服務(wù)建立異步鏈接,ip為遠程連接池服務(wù)的ip,如果是集群就是lvs的ip $sql_connection = new AsyncTcpConnection('Text://ip:1234'); // 發(fā)送sql $sql_connection->send("SELECT ... FROM ....."); // 異步獲得sql結(jié)果 $sql_connection->onMessage = function($sql_connection, $sql_result) { // 這里只是打印結(jié)果 var_dump(json_decode($task_result)); }; // 執(zhí)行異步鏈接 $sql_connection->connect();
看完了這篇文章,相信你對“workerman寫mysql連接池有什么用”有了一定的了解,如果想了解更多相關(guān)知識,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝各位的閱讀!
分享名稱:workerman寫mysql連接池有什么用
網(wǎng)址分享:http://jinyejixie.com/article16/iisddg.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)頁設(shè)計公司、用戶體驗、營銷型網(wǎng)站建設(shè)、網(wǎng)站營銷、網(wǎng)站建設(shè)、搜索引擎優(yōu)化
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)