佳木斯湛栽影视文化发展公司

主頁 > 知識庫 > workerman寫mysql連接池的實例代碼

workerman寫mysql連接池的實例代碼

熱門標(biāo)簽:Linux服務(wù)器 AI電銷 呼叫中心市場需求 地方門戶網(wǎng)站 服務(wù)外包 網(wǎng)站排名優(yōu)化 鐵路電話系統(tǒng) 百度競價排名

首先要了解為什么用連接池,連接池能為你解決什么問題

連接池主要的作用:

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

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

如果是為了解決問題1

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

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

如果是為了問題2

首先看下自己到底有多少臺應(yīng)用服務(wù)器,每臺服務(wù)器與mysql有多收并發(fā)連接。假如你只有10臺應(yīng)用服務(wù)器,每個服務(wù)器50個進(jìn)程,每個進(jìn)程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ù)也會輕松打滿。所以不要指望在當(dāng)前服務(wù)器上開幾個task進(jìn)程實現(xiàn)的連接池就能解決這個問題。

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

綜上所述,

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

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

 

// 與遠(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();

以上就是本次介紹的workerman寫mysql連接池全部知識點,有任何補充可以聯(lián)系腳本之家小編。

您可能感興趣的文章:
  • 詳解Spring Boot Mysql 版本驅(qū)動連接池方案選擇
  • Python 使用 PyMysql、DBUtils 創(chuàng)建連接池提升性能
  • Node.js使用MySQL連接池的方法實例
  • nodeJs實現(xiàn)基于連接池連接mysql的方法示例
  • Node.js實現(xiàn)mysql連接池使用事務(wù)自動回收連接的方法示例
  • php實現(xiàn)mysql連接池效果實現(xiàn)代碼
  • Python MySQL數(shù)據(jù)庫連接池組件pymysqlpool詳解
  • Java使用MySQL實現(xiàn)連接池代碼實例

標(biāo)簽:仙桃 衡水 湘潭 蘭州 銅川 崇左 黃山 湖南

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《workerman寫mysql連接池的實例代碼》,本文關(guān)鍵詞  ;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266
    泊头市| 庆云县| 长治市| 延庆县| 新闻| 公主岭市| 吉首市| 马鞍山市| 宜兰县| 武穴市| 荔波县| 吴桥县| 承德县| 麻城市| 汝南县| 和顺县| 湘西| 治县。| 辽源市| 应城市| 西盟| 广宁县| 保亭| 东平县| 水城县| 阳泉市| 上栗县| 兰考县| 芜湖县| 江永县| 绩溪县| 凤山市| 富民县| 伊宁市| 镇康县| 邢台市| 慈利县| 民丰县| 博白县| 耿马| 互助|