中文在线一区二区_欧美在线综合_久久久久久综合_欧美一区二区三区视频_国产免费看_国产福利精品一区

什么是連接池

連接池是創(chuàng)建和管理一個連接的緩沖池的技術(shù),這些連接準備好被任何需要它們的線程使用。

簡單來說,就是創(chuàng)建一個容器,并且把資源提前準備好放在里面,比如我們常用的redis連接、mysql連接。

連接池的優(yōu)點

計算機是由許多零件組裝而成,比如CPU、內(nèi)存、硬盤等等。

當我們進行網(wǎng)絡(luò)連接、請求的時候,就需要在不同組件中傳遞和返回各種信號、數(shù)據(jù)

比如在CPU、內(nèi)存、網(wǎng)卡中,數(shù)據(jù)的傳遞,請求,獲取。

如果在短時間內(nèi)進行一萬次mysql的連接,就需要在這個往返過程循環(huán),在路上浪費了很多時間、性能消耗。

如果我們先把連接連接好,并且放在連接池中,程序中需要使用就從池中獲取,執(zhí)行操作。

就省去了反復創(chuàng)建連接、斷開連接的操作。

可以減少I/O操作,提高資源利用率。

連接池數(shù)量如何設(shè)置

那么一個池需要設(shè)置多少數(shù)量比較合適呢?是不是越多越好?
連接數(shù)量需要根據(jù)并發(fā)數(shù),以及數(shù)據(jù)庫的處理情況來決定的,
比如你的數(shù)據(jù)庫最大只能處理500個連接,那你設(shè)置700個,數(shù)據(jù)庫照樣處理不過來,設(shè)置過多并沒有什么用處,反而可能會讓數(shù)據(jù)庫宕機
所以,一般情況下,連接池總數(shù)設(shè)置為100-200左右就夠了(相當于200的并發(fā))

這里的連接池數(shù)量,說的是總數(shù)量,在easyswoole中,需要根據(jù)進程來看,每個進程*連接池配置數(shù)量=總數(shù)量,比如easyswoole中worker進程為8,那你設(shè)置20個,那就是20*8=160的總數(shù)

easyswoole中為什么會pool empty

這個問題有好幾個可能性。

  • 連接信息錯誤,導致一個資源都沒有
  • 程序有問題,把資源拿出去,沒有歸還到池內(nèi),后續(xù)就拿到空了
  • 并發(fā)高,池的數(shù)量少,需要檢查資源占用率,如果占用率沒問題,則提高池內(nèi)的數(shù)量

連接錯誤

如果我們的mysql配置信息錯誤,在easyswoole框架啟動之后,就會去初始化連接池。

此時一直連接失敗,也就沒有產(chǎn)生資源,也沒有將資源放在池內(nèi)

當你在后續(xù)程序獲取池內(nèi)資源的時候。自然就報了空池的錯誤提示。

程序問題

先來一個連接池的偽代碼

<?php

class Pool{
    public static function getIn(){
        // 單例模式
    }
    /**
     * 初始化
     */
    public function init()
    {
        // pool準備好就填充指定的資源 比如10個連接
        $this->pool = $array;
    }

    public function get(){
        return array_pop($this->pool);
    }   
    public function push($obj)
    {
        $this->pool[] = $obj;
    }
}

如果我們的程序有這樣子的使用場景

<?php

    $db = Pool::getIn()->get();
    $res = $db->query('sql語句');

然后沒有進行push 歸還操作,那么池內(nèi)資源一旦拿完,就沒有資源可用了。

在easyswoole框架中,有提供以下方法獲取資源(以mysql-pool為例)

$db = MysqlPool::defer();
$db->rawQuery('select version()');
$data = MysqlPool::invoker(function (MysqlConnection $db){
    return $db->rawQuery('select version()');
});
$db = PoolManager::getInstance()->getPool(MysqlPool::class)->getObj();
$data = $db->get('test');
//使用完畢需要回收
PoolManager::getInstance()->getPool(MysqlPool::class)->recycleObj($db);

defer方法將會在本次請求協(xié)程退出的時候自動回收

invoker是閉包函數(shù)方式 一次運行完馬上自動回收

get方式 就是我們偽代碼的方式 需要自己回收 使用這種方式就需要特別注意啦~!!!

兩種自動回收方式怎么選擇 請接著往下看!

并發(fā)高 資源占用率

上面說到兩種自動回收資源的方式,defer和invoker

首先我們來看一個點,defer是在協(xié)程退出時自動回收,正常來說,在一個請求到達的時候,swoole會自動創(chuàng)建一個協(xié)程給他,比如我們一個http api的請求,就需要整個api跑完,這個協(xié)程才會退出

(相當于我們傳統(tǒng)fpm php中 一個腳本全部執(zhí)行完)

這個時候問題來了,如果我們的業(yè)務是這樣子的

<?php

    $db = MysqlPool::defer();
    $db->rawQuery('select version()');

    // 執(zhí)行好mysql了  做其他任務

    // 耗時1.5s 完成其他

實際上使用到mysql資源的可能只有0.1s不到,但是其他運算占用了腳本大量執(zhí)行時間,要等全部執(zhí)行完,協(xié)程退出了,資源才會回收,這個時候就比較浪費資源的利用率了。占用率比較低。 ! 如果可以的話 ,我們推薦使用invoker 執(zhí)行一條 馬上回收資源

此時要注意一個點,如果程序有比較多執(zhí)行語句,要么在一個invoker里執(zhí)行,要么合理使用invoker

不然就會把性能消耗轉(zhuǎn)移到不斷get recycle上了

如果以上排查都沒問題,并且確認你的用戶量比較多,并發(fā)高,就可以適當提高pool的number

主站蜘蛛池模板: 香蕉视频在线看 | 亚洲精品一二三 | 99re6在线视频精品免费 | 精品久久中文字幕 | 欧美激情一区二区三级高清视频 | 亚洲二区在线观看 | 欧美一区二区三区四区五区 | 日韩欧美专区 | 成人av入口 | 国户精品久久久久久久久久久不卡 | 久久99国产精品久久99大师 | 欧美大片免费影院在线观看 | 精品国产黄a∨片高清在线 久草.com | 国产一区二区三区久久久久久久久 | 91亚洲精品一区 | 国产精品久久久久久久久免费桃花 | 亚洲欧美视频在线 | 成人免费毛片aaaaaa片 | 欧美一区二区在线刺激视频 | 国产一级一级特黄女人精品毛片 | 午夜视频在线播放 | 2015成人永久免费视频 | 久久99国产精一区二区三区 | 日夜夜精品视频 | 中文字幕乱码亚洲精品一区 | 在线午夜 | 亚洲成人av在线播放 | 日韩精品在线免费观看 | 在线精品一区二区 | 日韩一区二区免费电影 | 一性一交一色生活片 | 四虎永久免费影视 | 高清视频一区 | 国产成人一区 | 亚洲视频在线免费观看 | 成人在线观看免费 | 91在线网址 | 欧美资源在线 | 久久精品国产99国产精品 | 日韩高清一区 | 亚洲精品国产综合区久久久久久久 |