基于swoole的數(shù)據(jù)庫連接池

服務(wù)端代碼

<?php

$serv = new swoole_server("127.0.0.1", 9501);//監(jiān)聽127.0.0.1
$serv->set(array(
    'worker_num' => 100,//這里設(shè)置為CPU的1-4倍最合理
    'task_worker_num' => 10, //MySQL連接的數(shù)量
));

function my_onReceive($serv, $fd, $from_id, $data)
{
    //taskwait就是投遞一條任務(wù)猴仑,這里直接傳遞SQL語句了
    //然后阻塞等待SQL完成
    $result = $serv->taskwait($data);
    if ($result !== false) {
//        list($status, $db_res) = explode(':', $result, 2);
//        if ($status == 'OK') {
            //數(shù)據(jù)庫操作成功了剥扣,執(zhí)行業(yè)務(wù)邏輯代碼希痴,這里就自動釋放掉MySQL連接的占用
            $serv->send($fd, $result);
//        } else {
//            $serv->send($fd, $db_res);
//        }
        return;
    } else {
        $serv->send($fd, "Error. Task timeout\n");
    }
}

function my_onTask($serv, $task_id, $from_id, $sql)
{
    static $link = null;
    if ($link == null) {
        $link = mysqli_connect("host", "username", "password", "dbname");
        if (!$link) {
            $link = null;
            $serv->finish("ER:" . mysqli_error($link));
            return;
        }
    }
    $result = $link->query($sql);
    if (!$result) {
        $serv->finish("ER:" . mysqli_error($link));
        return;
    }
    $data = $result->fetch_all(MYSQLI_ASSOC);
    $serv->finish(json_encode($data));
}

function my_onFinish($serv, $data)
{
    echo "AsyncTask Finish:Connect.PID=" . posix_getpid() . PHP_EOL;
}

$serv->on('Receive', 'my_onReceive');
$serv->on('Task', 'my_onTask');
$serv->on('Finish', 'my_onFinish');
$serv->start();

以下為客戶端代碼

<?php

$client = new swoole_client(SWOOLE_SOCK_TCP);

//連接到服務(wù)器
if (!$client->connect('127.0.0.1', 9501, 0.5))
{
    die("connect failed.");
}
//向服務(wù)器發(fā)送數(shù)據(jù)
if (!$client->send("sql語句"))
{
    die("send failed.");
}
//從服務(wù)器接收數(shù)據(jù)
$data = $client->recv();
if (!$data)
{
    die("recv failed.");
}
echo '<pre>';
var_dump(json_decode($data)) ;
//關(guān)閉連接
$client->close();
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末宾茂,一起剝皮案震驚了整個濱河市阔蛉,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌友绝,老刑警劉巖屎篱,帶你破解...
    沈念sama閱讀 211,290評論 6 491
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異啰劲,居然都是意外死亡梁沧,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,107評論 2 385
  • 文/潘曉璐 我一進店門蝇裤,熙熙樓的掌柜王于貴愁眉苦臉地迎上來廷支,“玉大人频鉴,你說我怎么就攤上這事×蹬模” “怎么了垛孔?”我有些...
    開封第一講書人閱讀 156,872評論 0 347
  • 文/不壞的土叔 我叫張陵,是天一觀的道長施敢。 經(jīng)常有香客問我似炎,道長,這世上最難降的妖魔是什么悯姊? 我笑而不...
    開封第一講書人閱讀 56,415評論 1 283
  • 正文 為了忘掉前任羡藐,我火速辦了婚禮,結(jié)果婚禮上悯许,老公的妹妹穿的比我還像新娘仆嗦。我一直安慰自己,他們只是感情好先壕,可當我...
    茶點故事閱讀 65,453評論 6 385
  • 文/花漫 我一把揭開白布瘩扼。 她就那樣靜靜地躺著,像睡著了一般垃僚。 火紅的嫁衣襯著肌膚如雪集绰。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,784評論 1 290
  • 那天谆棺,我揣著相機與錄音栽燕,去河邊找鬼。 笑死改淑,一個胖子當著我的面吹牛碍岔,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播朵夏,決...
    沈念sama閱讀 38,927評論 3 406
  • 文/蒼蘭香墨 我猛地睜開眼蔼啦,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了仰猖?” 一聲冷哼從身側(cè)響起捏肢,我...
    開封第一講書人閱讀 37,691評論 0 266
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎饥侵,沒想到半個月后鸵赫,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,137評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡爆捞,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,472評論 2 326
  • 正文 我和宋清朗相戀三年奉瘤,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 38,622評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡盗温,死狀恐怖藕赞,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情卖局,我是刑警寧澤斧蜕,帶...
    沈念sama閱讀 34,289評論 4 329
  • 正文 年R本政府宣布,位于F島的核電站砚偶,受9級特大地震影響批销,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜染坯,卻給世界環(huán)境...
    茶點故事閱讀 39,887評論 3 312
  • 文/蒙蒙 一均芽、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧单鹿,春花似錦掀宋、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,741評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至儒喊,卻和暖如春镣奋,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背怀愧。 一陣腳步聲響...
    開封第一講書人閱讀 31,977評論 1 265
  • 我被黑心中介騙來泰國打工侨颈, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人掸驱。 一個月前我還...
    沈念sama閱讀 46,316評論 2 360
  • 正文 我出身青樓肛搬,卻偏偏與公主長得像,于是被迫代替她去往敵國和親毕贼。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 43,490評論 2 348