成人午夜视频全免费观看高清-秋霞福利视频一区二区三区-国产精品久久久久电影小说-亚洲不卡区三一区三区一区

swoole的mysql連接池怎么弄

這篇文章給大家分享的是有關swoole的MySQL連接池怎么弄的內容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。

創(chuàng)新互聯(lián)專注于西充企業(yè)網(wǎng)站建設,響應式網(wǎng)站建設,商城網(wǎng)站開發(fā)。西充網(wǎng)站建設公司,為西充等地區(qū)提供建站服務。全流程定制設計,專業(yè)設計,全程項目跟蹤,創(chuàng)新互聯(lián)專業(yè)和態(tài)度為您提供的服務

傳統(tǒng)的nginx+FPM模式的PHP程序而言,每次請求FPM的worker都會連接一次mysql,然后請求結束便會斷開連接。對于并發(fā)小的應用來說這不會有什么問題,但是對于高并發(fā)的應用來說,頻繁建立連接Connect和銷毀連接Close,數(shù)據(jù)庫便會成為瓶頸,相信不少人也遇到過to many connection的mysql報錯吧。

連接池的優(yōu)勢

連接池采用的是長連接模式,會一直保持與MySQL的連接,用完后會重新放回連接池,從而節(jié)省了建立連接和斷開連接的消耗,大大降低了系統(tǒng)IO的消耗,一定程度上提高了程序的并發(fā)性能。如果連接池空閑,就從連接池分配一個連接,否則,請求將被加入到等待隊列中。

實現(xiàn)

我們采用swoole實現(xiàn)mysql連接池

連接池類
<?php

require_once "MysqlDB.php";class MysqlPool{
    private static $instance;
    private $pool;
    private $config;
    private $pool_get_timeout;

    /**
     * 獲取mysql進程池單例
     * @param null $config
     * @return MysqlPool
     */
    public static function getInstance($config = null)
    {
        if (empty(self::$instance)) {
            if (empty($config)) {
                throw new RuntimeException("mysql config is empty");
            }
            self::$instance = new static($config);
        }
        return self::$instance;
    }

    public function __construct($config)
    {
        if (empty($this->pool)) {
            $this->config = $config;
            $this->pool = new \Swoole\Coroutine\Channel($config['pool_size']);
            for ($i = 0; $i < $config['pool_size']; $i++) {
                \go(function() use ($config) {
                    $mysql = new MysqlDB();
                    $res = $mysql->connect($config['mysql']);
                    if ($res === false) {
                        throw new RuntimeException("Failed to connect mysql server");
                    } else {
                        $this->pool->push($mysql);
                    }
                });
            }
        }
    }

    public function get()
    {
        if ($this->pool->length() > 0) {
            $mysql = $this->pool->pop($this->config['pool_get_timeout']);
            if (false === $mysql) {
                throw new RuntimeException("Pop mysql timeout");
            }
            return $mysql;
        } else {
            throw new RuntimeException("Pool length <= 0");
        }
    }

    public function recycle(MysqlDB $mysql){
        $this->pool->push($mysql);
    }

    /**
     * 獲取連接池長度
     * @return mixed
     */
    public function getPoolSize(){
        return $this->pool->length();
    }}
數(shù)據(jù)庫DB類
<?phpclass MysqlDB{
    private $connection;

    public function connect($config)
    {
        $connection = new \Swoole\Coroutine\MySQL();
        $res = $connection->connect($config);
        if ($res === false) {
            throw new RuntimeException($connection->connect_error, $connection->errno);
        } else {
            $this->connection = $connection;
        }
        return $res;
    }


    public function query($sql){
        $result = $this->connection->query($sql);
        return $result;
    }}
在HTTP協(xié)程服務器中創(chuàng)建連接池
<?php
require_once "MysqlPool.php";\Co\run(function () {
    $server = new \Co\Http\Server("0.0.0.0", 9501, false);
    $pool = MysqlPool::getInstance([
        'pool_size'=>5,
        'pool_get_timeout'=>1,
        'timeout'=>1,
        'charset'=>'utf8',
        'strict_type'=>false,
        'fetch_mode'=>true,
        'mysql'=>[
            'host'=>'127.0.0.1',
            'port'=>'3306',
            'user'=>'homestead',
            'password'=>'secret',
            'database'=>'blog',
        ]
    ]);
    $server->handle('/', function ($request, $response) use ($pool){
        $mysql = $pool->get();
        $res = $mysql->query("select id,phone,username from user limit 1");
        var_dump($res);
        $pool->recycle($mysql);
        $response->end("<h2>Test</h2>");
    });
    $server->handle('/test', function ($request, $response) {
        $response->end("<h2>Test</h2>");
    });
    $server->handle('/stop', function ($request, $response) use ($server) {
        $response->end("<h2>Stop</h2>");
        $server->shutdown();
    });
    $server->start();});
源碼地址 swoole-mysql-pool

感謝各位的閱讀!關于“swoole的mysql連接池怎么弄”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!

文章名稱:swoole的mysql連接池怎么弄
網(wǎng)站鏈接:http://jinyejixie.com/article46/pddpeg.html

成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站制作、靜態(tài)網(wǎng)站營銷型網(wǎng)站建設、網(wǎng)頁設計公司網(wǎng)站設計、手機網(wǎng)站建設

廣告

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

外貿網(wǎng)站制作
华坪县| 萨迦县| 丰台区| 普陀区| 沙坪坝区| 朔州市| 新干县| 大田县| 简阳市| 惠州市| 东兰县| 岳阳市| 金华市| 若尔盖县| 江陵县| 喀喇沁旗| 正定县| 景德镇市| 朔州市| 双辽市| 威信县| 玉山县| 九龙坡区| 扶余县| 凤凰县| 阿合奇县| 茌平县| 焉耆| 海口市| 潞西市| 渭源县| 基隆市| 芒康县| 广东省| 清新县| 昌乐县| 武宁县| 巴林右旗| 长宁县| 河南省| 达日县|