<span id="mktg5"></span>

<i id="mktg5"><meter id="mktg5"></meter></i>

        <label id="mktg5"><meter id="mktg5"></meter></label>
        最新文章專題視頻專題問答1問答10問答100問答1000問答2000關(guān)鍵字專題1關(guān)鍵字專題50關(guān)鍵字專題500關(guān)鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關(guān)鍵字專題關(guān)鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
        問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
        當前位置: 首頁 - 科技 - 知識百科 - 正文

        基于Swoole擴展開發(fā)異步高性能的MySQL代理服務(wù)器_MySQL

        來源:懂視網(wǎng) 責編:小采 時間:2020-11-09 19:26:23
        文檔

        基于Swoole擴展開發(fā)異步高性能的MySQL代理服務(wù)器_MySQL

        基于Swoole擴展開發(fā)異步高性能的MySQL代理服務(wù)器_MySQL:代理服務(wù)器 MySQL數(shù)據(jù)庫對每個客戶端連接都會分配一個線程,所以連接非常寶貴。開發(fā)一個異步的MySQL代理服務(wù)器,PHP應(yīng)用服務(wù)器可以長連接到這臺Server,既減輕MYSQL的連接壓力,又使PHP保持長連接減少connect/close的網(wǎng)絡(luò)開銷。 此Server考慮
        推薦度:
        導讀基于Swoole擴展開發(fā)異步高性能的MySQL代理服務(wù)器_MySQL:代理服務(wù)器 MySQL數(shù)據(jù)庫對每個客戶端連接都會分配一個線程,所以連接非常寶貴。開發(fā)一個異步的MySQL代理服務(wù)器,PHP應(yīng)用服務(wù)器可以長連接到這臺Server,既減輕MYSQL的連接壓力,又使PHP保持長連接減少connect/close的網(wǎng)絡(luò)開銷。 此Server考慮

        代理服務(wù)器

        MySQL數(shù)據(jù)庫對每個客戶端連接都會分配一個線程,所以連接非常寶貴。開發(fā)一個異步的MySQL代理服務(wù)器,PHP應(yīng)用服務(wù)器可以長連接到這臺Server,既減輕MYSQL的連接壓力,又使PHP保持長連接減少connect/close的網(wǎng)絡(luò)開銷。

        此Server考慮到了設(shè)置了數(shù)據(jù)庫連接池尺寸,區(qū)分忙閑,mysqli斷線重連,并設(shè)置了負載保護。基于swoole擴展開發(fā),io循環(huán)使用epoll,是全異步非阻塞的,可以應(yīng)對大量TCP連接。

        程序的邏輯是:啟動時創(chuàng)建N個MySQL連接,收到客戶端發(fā)來的SQL后,分配1個MySQL連接,將SQL發(fā)往數(shù)據(jù)庫服務(wù)器。然后等待數(shù)據(jù)庫返回查詢結(jié)果。當數(shù)據(jù)庫返回結(jié)果后,再發(fā)給對應(yīng)的客戶端連接。

        核心的數(shù)據(jù)結(jié)構(gòu)是3個PHP數(shù)組。idle_pool是空閑的數(shù)據(jù)庫連接,當有SQL請求時從idle_pool中移到busy_pool中。當數(shù)據(jù)庫返回結(jié)果后從busy_pool中再移到idle_pool中,以供新的請求使用。當SQL請求到達時如果沒有空閑的數(shù)據(jù)庫連接,那會自動加入到wait_queue中。一旦有SQL完成操作,將自動從wait_queue中取出等待的請求進行處理。

        如此循環(huán)使用。由于整個服務(wù)器是異步的單進程單線程所以完全不需要鎖。而且是完全異步的,效率非常高。

        當然本文的代碼,如果要用于生產(chǎn)環(huán)境,還需做更多的保護機制和壓力測試。在此僅拋磚引玉,提供一個解決問題的思路。

        class DBServer{ protected $pool_size = 20; protected $idle_pool = array(); //空閑連接 protected $busy_pool = array(); //工作連接 protected $wait_queue = array(); //等待的請求 protected $wait_queue_max = 100; //等待隊列的最大長度,超過后將拒絕新的請求 /** * @var swoole_server */ protected $serv; function run() { $serv = new swoole_server("127.0.0.1", 9509); $serv->set(array( 'worker_num' => 1, )); $serv->on('WorkerStart', array($this, 'onStart')); //$serv->on('Connect', array($this, 'onConnect')); $serv->on('Receive', array($this, 'onReceive')); //$serv->on('Close', array($this, 'onClose')); $serv->start(); } function onStart($serv) { $this->serv = $serv; for ($i = 0; $i < $this->pool_size; $i++) { $db = new mysqli; $db->connect('127.0.0.1', 'root', 'root', 'test'); $db_sock = swoole_get_mysqli_sock($db); swoole_event_add($db_sock, array($this, 'onSQLReady')); $this->idle_pool[] = array( 'mysqli' => $db, 'db_sock' => $db_sock, 'fd' => 0, ); } echo "Server: start.Swoole version is [" . SWOOLE_VERSION . "]/n"; } function onSQLReady($db_sock) { $db_res = $this->busy_pool[$db_sock]; $mysqli = $db_res['mysqli']; $fd = $db_res['fd']; echo __METHOD__ . ": client_sock=$fd|db_sock=$db_sock/n"; if ($result = $mysqli->reap_async_query()) { $ret = var_export($result->fetch_all(MYSQLI_ASSOC), true) . "/n"; $this->serv->send($fd, $ret); if (is_object($result)) { mysqli_free_result($result); } } else { $this->serv->send($fd, sprintf("MySQLi Error: %s/n", mysqli_error($mysqli))); } //release mysqli object $this->idle_pool[] = $db_res; unset($this->busy_pool[$db_sock]); //這里可以取出一個等待請求 if (count($this->wait_queue) > 0) { $idle_n = count($this->idle_pool); for ($i = 0; $i < $idle_n; $i++) { $req = array_shift($this->wait_queue); $this->doQuery($req['fd'], $req['sql']); } } } function onReceive($serv, $fd, $from_id, $data) { //沒有空閑的數(shù)據(jù)庫連接 if (count($this->idle_pool) == 0) { //等待隊列未滿 if (count($this->wait_queue) < $this->wait_queue_max) { $this->wait_queue[] = array( 'fd' => $fd, 'sql' => $data, ); } else { $this->serv->send($fd, "request too many, Please try again later."); } } else { $this->doQuery($fd, $data); } } function doQuery($fd, $sql) { //從空閑池中移除 $db = array_pop($this->idle_pool); /** * @var mysqli */ $mysqli = $db['mysqli']; for ($i = 0; $i < 2; $i++) { $result = $mysqli->query($sql, MYSQLI_ASYNC); if ($result === false) { if ($mysqli->errno == 2013 or $mysqli->errno == 2006) { $mysqli->close(); $r = $mysqli->connect(); if ($r === true) continue; } } break; } $db['fd'] = $fd; //加入工作池中 $this->busy_pool[$db['db_sock']] = $db; }}$server = new DBServer();$server->run();

        聲明:本網(wǎng)頁內(nèi)容旨在傳播知識,若有侵權(quán)等問題請及時與本網(wǎng)聯(lián)系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

        文檔

        基于Swoole擴展開發(fā)異步高性能的MySQL代理服務(wù)器_MySQL

        基于Swoole擴展開發(fā)異步高性能的MySQL代理服務(wù)器_MySQL:代理服務(wù)器 MySQL數(shù)據(jù)庫對每個客戶端連接都會分配一個線程,所以連接非常寶貴。開發(fā)一個異步的MySQL代理服務(wù)器,PHP應(yīng)用服務(wù)器可以長連接到這臺Server,既減輕MYSQL的連接壓力,又使PHP保持長連接減少connect/close的網(wǎng)絡(luò)開銷。 此Server考慮
        推薦度:
        • 熱門焦點

        最新推薦

        猜你喜歡

        熱門推薦

        專題
        Top
        主站蜘蛛池模板: 亚洲1234区乱码| 亚洲国产日产无码精品| 免费无遮挡无遮羞在线看| 日本免费一区尤物| 最新亚洲人成无码网站| 又大又硬又爽免费视频| 免费又黄又爽又猛大片午夜| 亚洲成A人片在线观看中文| 一级人做人a爰免费视频 | 成全视频高清免费观看电视剧| 亚洲日韩国产精品乱| 精品一区二区三区免费视频| 在线亚洲人成电影网站色www| 99精品全国免费观看视频..| 亚洲天天在线日亚洲洲精| 91香焦国产线观看看免费| 91亚洲自偷在线观看国产馆| 最好免费观看韩国+日本| 香蕉国产在线观看免费| 亚洲色精品vr一区二区三区| 日本xxxx色视频在线观看免费| 亚洲色av性色在线观无码| 天天看免费高清影视| eeuss影院免费直达入口| 亚洲AV无码日韩AV无码导航| 免费看成人AA片无码视频羞羞网| 亚洲精品无码成人| 国产精品亚洲二区在线观看| 无码日韩精品一区二区免费暖暖| 亚洲伊人久久精品| 亚洲AV无码乱码在线观看| 一级毛片免费不卡在线| 亚洲av永久无码精品秋霞电影秋 | 亚洲伊人精品综合在合线| 亚洲?V无码乱码国产精品| 美女内射无套日韩免费播放| 中国china体内裑精亚洲日本| 亚洲精品无码日韩国产不卡?V | 国产在线观看免费不卡| 麻豆精品不卡国产免费看| 中文字幕亚洲精品无码|