workerman寫(xiě)mysql連接池的方法以及作用是什么

今天就跟大家聊聊有關(guān)workerman寫(xiě)MySQL連接池的方法以及作用是什么,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結(jié)了以下內(nèi)容,希望大家根據(jù)這篇文章可以有所收獲。

創(chuàng)新互聯(lián)建站專注于企業(yè)成都營(yíng)銷網(wǎng)站建設(shè)、網(wǎng)站重做改版、羅平網(wǎng)站定制設(shè)計(jì)、自適應(yīng)品牌網(wǎng)站建設(shè)、H5技術(shù)電子商務(wù)商城網(wǎng)站建設(shè)、集團(tuán)公司官網(wǎng)建設(shè)、外貿(mào)網(wǎng)站制作、高端網(wǎng)站制作、響應(yīng)式網(wǎng)頁(yè)設(shè)計(jì)等建站業(yè)務(wù),價(jià)格優(yōu)惠性價(jià)比高,為羅平等各大城市提供網(wǎng)站開(kāi)發(fā)制作服務(wù)。

首先要了解為什么用連接池,連接池能為你解決什么問(wèn)題

連接池主要的作用:

1、減少與數(shù)據(jù)服務(wù)器建立TCP連接三次握手及連接關(guān)閉四次揮手的開(kāi)銷,從而降低客戶端和mysql服務(wù)端的負(fù)載,縮短請(qǐng)求響應(yīng)時(shí)間

2、減少數(shù)據(jù)庫(kù)的并發(fā)連接數(shù),即解決應(yīng)用服務(wù)器過(guò)多導(dǎo)致的數(shù)據(jù)庫(kù) too many connections 問(wèn)題

如果是為了解決問(wèn)題1

則在workerman中數(shù)據(jù)庫(kù)連接池不是最高效的方法,反而是自找麻煩的做法。由于PHP是單進(jìn)程單線程的,使用PHP實(shí)現(xiàn)數(shù)據(jù)庫(kù)連接池,肯定需要用單獨(dú)的進(jìn)程去做,那么就會(huì)涉及到進(jìn)程間的通訊,使得原本和mysql直接通訊的過(guò)程變成 與連接池再到mysql的通訊,增加了應(yīng)用端的負(fù)載。

解決問(wèn)題1最高效的方法是為每個(gè)業(yè)務(wù)進(jìn)程建立一個(gè)數(shù)據(jù)庫(kù)單例(例如workerman提供的DB類),實(shí)現(xiàn)數(shù)據(jù)庫(kù)長(zhǎng)連接,這樣每個(gè)進(jìn)程的所有請(qǐng)求都使用自己的這一個(gè)數(shù)據(jù)庫(kù)長(zhǎng)連接,整個(gè)進(jìn)程的生命周期只有一次TCP握手和斷開(kāi)連接揮手的開(kāi)銷,并且應(yīng)用與mysql直接通訊,沒(méi)有連接池那樣中間一層進(jìn)程間IPC通訊,性能是最高的,沒(méi)有之一。

如果是為了問(wèn)題2

首先看下自己到底有多少臺(tái)應(yīng)用服務(wù)器,每臺(tái)服務(wù)器與mysql有多收并發(fā)連接。假如你只有10臺(tái)應(yīng)用服務(wù)器,每個(gè)服務(wù)器50個(gè)進(jìn)程,每個(gè)進(jìn)程1個(gè)數(shù)據(jù)庫(kù)連接,那么到mysql服務(wù)端總共只有10*50=500個(gè)并發(fā)連接(并非活躍連接),500個(gè)并發(fā)連接對(duì)于mysql來(lái)說(shuō)就是小菜一碟,為了解決問(wèn)題2完全沒(méi)有使用連接池的必要。

假如你有1000臺(tái)應(yīng)用服務(wù)器,那么連接池是有必要的,但是這個(gè)連接池不能是運(yùn)行在本地應(yīng)用服務(wù)器上的連接池,因?yàn)?000臺(tái)應(yīng)用服務(wù)器就有1000個(gè)連接池,即使每個(gè)連接池只開(kāi)10個(gè)連接,那么數(shù)據(jù)庫(kù)的連接數(shù)也會(huì)輕松打滿。所以不要指望在當(dāng)前服務(wù)器上開(kāi)幾個(gè)task進(jìn)程實(shí)現(xiàn)的連接池就能解決這個(gè)問(wèn)題。

1000臺(tái)應(yīng)用服務(wù)器的集群,每臺(tái)服務(wù)器上搞幾個(gè)進(jìn)程實(shí)現(xiàn)連接池同樣是不靠譜的方法。真正能夠解決問(wèn)題2的方法是建立一個(gè)獨(dú)立的數(shù)據(jù)庫(kù)連接池服務(wù)器或者說(shuō)集群,全局管理所有的數(shù)據(jù)庫(kù)鏈接。

綜上所述,

如果單獨(dú)是為了問(wèn)題1實(shí)現(xiàn)php的mysql連接池,那么數(shù)據(jù)庫(kù)單例是比所謂的連接池更簡(jiǎn)單更高效的做法。

如果是為了實(shí)現(xiàn)問(wèn)題2,那么想必業(yè)務(wù)也有一定的規(guī)模了,如果真心是想用workerman做個(gè)單獨(dú)的連接池集群,下面是大概簡(jiǎn)單的做法,建立一些task進(jìn)程,每個(gè)進(jìn)程創(chuàng)建一個(gè)數(shù)據(jù)庫(kù)連接,task進(jìn)程收到sql請(qǐng)求后發(fā)送給mysql服務(wù)器,mysql服務(wù)器返回后task進(jìn)程再把結(jié)果發(fā)給sql發(fā)起者。

連接池代碼類似如下 如果是多臺(tái)服務(wù)器組成的連接池集群,前面最好加一個(gè)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;

// 與遠(yuǎn)程連接池服務(wù)建立異步鏈接,ip為遠(yuǎn)程連接池服務(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();

看完上述內(nèi)容,你們對(duì)workerman寫(xiě)mysql連接池的方法以及作用是什么有進(jìn)一步的了解嗎?如果還想了解更多知識(shí)或者相關(guān)內(nèi)容,請(qǐng)關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝大家的支持。

當(dāng)前文章:workerman寫(xiě)mysql連接池的方法以及作用是什么
瀏覽地址:http://bm7419.com/article12/jdccgc.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站制作服務(wù)器托管、微信公眾號(hào)、ChatGPT、微信小程序品牌網(wǎng)站設(shè)計(jì)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

外貿(mào)網(wǎng)站建設(shè)