ThinkPHP5和無框架代碼在高併發下的效率對比

測試的業務邏輯:測試一個抽獎功能,使用MySQL數據庫的樂觀鎖機制防止超發。php

關鍵代碼:nginx

$prizeArr = array(
            array('level' => 1, 'name' => '手機', 'randnum' => 10),
            array('level' => 2, 'name' => '100元話費', 'randnum' => 5010),
            array('level' => 3, 'name' => '自拍杆', 'randnum' => 15010),
            array('level' => 4, 'name' => '5元紅包', 'randnum' => 115010),
        );web

        $rand_num = mt_rand(1, 115010);
        $level = 4;
        
        for ($i = 0; $i < 4; $i++) {
            if ($rand_num <= $prizeArr[$i]['randnum']) {
                $level = $prizeArr[$i]['level'];
                break;
            }
        }    sql

不用框架代碼:數據庫

$sql = "select * from `lottory` where id=".$level." ";
    $res = $rnpdo->RnFetchRow($sql, array());
    $dataNum = $res['errmsg']['prizenum'];    //剩餘數量
    $version = $res['errmsg']['version'];    //版本號
    
    $updatesql = "update `lottory` set prizenum=prizenum-1,version=version+1 where id=".$level." and version=".$version." ";
    $updateres = $rnpdo->RnExec($updatesql, array());
    //print_r($res);
    if(!empty($updateres['errmsg'])) {
        //插入抽獎記錄
        $openid = $version.'-'.createOpenid();
        $time = time();
        $insertSql = "insert into `lottory_list` ( `openid`, `prize`, `posttime`) values ('$openid','$level','$time') ";
        $rnpdo->RnPtmQuery($insertSql, array());
        
        echo 'success';
    }
    else
    {
        echo 'fail';
    }緩存

使用thinkPHP5代碼部分:服務器

$res = Db::table("lottory")->where('id',$level)->find();
        
        $dataNum = $res['prizenum'];    //剩餘數量
        $version = $res['version'];    //版本號
        dump($res);
        
        $result = Db::table('lottory')->where('id', $level)->where('version', $version)->update(['prizenum' => ['exp','prizenum-1'],'version' => ['exp','version+1']]);
        dump($result);
        if($result) {
            //插入抽獎記錄
            $openid = $version.'-'.createOpenid();
            $time = time();
            $data = ['openid' => $openid, 'prize' => $level,'posttime'=>$time];
            Db::table('lottory_list')->insert($data);
            
            echo 'success';
        }
        else
        {
            echo 'fail';
        }併發

使用ab測試高併發下的表現:框架

ab -c 1000 -n 10000 http://localhost/lottory.php高併發

ab -c 1000 -n 10000 http://localhost/index.php?s=index/index/hello

測試在同一服務器上,web服務器使用nginx,其中TP5取消了日誌寫入(第一次沒有去掉,QPS更低)。

其中關鍵數據:

無框架QPS:Requests per second:   972.21 [#/sec] (mean)

thinkPHP5:Requests per second:    206.92 [#/sec] (mean)

一樣的業務邏輯,無框架是tp5的4.7倍。

不知道TP5是否是還有什麼地方沒有優化,兩個頁面代碼均沒有使用緩存。

各位大神有對tp5瞭解深的指導一下,是否還有其它地方要優化?

相關文章
相關標籤/搜索