欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

workerman寫mysql連接池的實(shí)例代碼

 更新時(shí)間:2020年01月20日 10:23:29   作者:尚  
在本篇文章中小編給大家分享的是一篇關(guān)于workerman寫mysql連接池的實(shí)例代碼內(nèi)容,有需要的朋友們可以參考下。

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

連接池主要的作用:

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

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

如果是為了解決問題1

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

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

如果是為了問題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ù)庫連接,那么到mysql服務(wù)端總共只有10*50=500個(gè)并發(fā)連接(并非活躍連接),500個(gè)并發(fā)連接對(duì)于mysql來說就是小菜一碟,為了解決問題2完全沒有使用連接池的必要。

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

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

綜上所述,

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

如果是為了實(shí)現(xiàn)問題2,那么想必業(yè)務(wù)也有一定的規(guī)模了,如果真心是想用workerman做個(gè)單獨(dú)的連接池集群,下面是大概簡(jiǎn)單的做法,建立一些task進(jìn)程,每個(gè)進(jìn)程創(chuàng)建一個(gè)數(shù)據(jù)庫連接,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();

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

相關(guān)文章

  • mysql存儲(chǔ)過程游標(biāo)之loop循環(huán)解讀

    mysql存儲(chǔ)過程游標(biāo)之loop循環(huán)解讀

    這篇文章主要介紹了mysql存儲(chǔ)過程游標(biāo)之loop循環(huán)解讀,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-07-07
  • mysql 將字段time按天/月/年分組

    mysql 將字段time按天/月/年分組

    表中有一個(gè)字段time,格式為Unix時(shí)間戳,現(xiàn)需要按照該字段統(tǒng)計(jì)每天的記錄數(shù)并按天/月/年分組
    2014-07-07
  • Linux如何添加mysql系統(tǒng)環(huán)境變量

    Linux如何添加mysql系統(tǒng)環(huán)境變量

    這篇文章主要介紹了Linux如何添加mysql系統(tǒng)環(huán)境變量問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-04-04
  • 如何快速修改MySQL用戶的host屬性

    如何快速修改MySQL用戶的host屬性

    這篇文章主要介紹了修改MySQL用戶的host屬性操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2021-01-01
  • 自用mysql自帶命令實(shí)現(xiàn)數(shù)據(jù)庫備份還原的方法

    自用mysql自帶命令實(shí)現(xiàn)數(shù)據(jù)庫備份還原的方法

    本文章介紹了都是mysql常用的命令一些數(shù)據(jù)導(dǎo)入導(dǎo)出的命令了,只要我們撐握這些命令就可以方法快速的給我們的數(shù)據(jù)庫進(jìn)行備份還原了
    2012-04-04
  • MySQL統(tǒng)計(jì)今日生成create_time的數(shù)據(jù)量的方法小結(jié)

    MySQL統(tǒng)計(jì)今日生成create_time的數(shù)據(jù)量的方法小結(jié)

    create_time通常是一個(gè)用于表示某個(gè)實(shí)體或事件創(chuàng)建時(shí)間的字段,在數(shù)據(jù)庫設(shè)計(jì)、日志記錄或許多軟件系統(tǒng)中常見,它存儲(chǔ)的是一個(gè)日期或時(shí)間戳,記錄了數(shù)據(jù)首次被創(chuàng)建的具體時(shí)刻,本文介紹了MySQL統(tǒng)計(jì)今日生成create_time的數(shù)據(jù)量的方法,需要的朋友可以參考下
    2024-08-08
  • MYSQL插入數(shù)據(jù)時(shí)檢查字段值是否重復(fù)的方法詳解

    MYSQL插入數(shù)據(jù)時(shí)檢查字段值是否重復(fù)的方法詳解

    這篇文章主要給大家介紹了關(guān)于MYSQL插入數(shù)據(jù)時(shí)檢查字段值是否重復(fù)的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2022-01-01
  • Mysql兩表聯(lián)合查詢的四種情況總結(jié)

    Mysql兩表聯(lián)合查詢的四種情況總結(jié)

    今天小編就為大家分享一篇關(guān)于Mysql兩表聯(lián)合查詢的四種情況總結(jié),小編覺得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來看看吧
    2019-01-01
  • 深入Mysql字符集設(shè)置分析

    深入Mysql字符集設(shè)置分析

    深入Mysql字符集設(shè)置分析,使用mysql的朋友可以參考下
    2012-03-03
  • MySQL中distinct和group?by去重效率區(qū)別淺析

    MySQL中distinct和group?by去重效率區(qū)別淺析

    distinct 與 group by均可用于去重,下面這篇文章主要給大家介紹了關(guān)于MySQL中distinct和group?by去重效率區(qū)別的相關(guān)資料,文中介紹的非常詳細(xì),需要的朋友可以參考下
    2023-03-03

最新評(píng)論