ホームページ >PHPフレームワーク >ThinkPHP >高同時実行下での ThinkPHP5 とフレームワークレス コードの効率を比較する

高同時実行下での ThinkPHP5 とフレームワークレス コードの効率を比較する

藏色散人
藏色散人転載
2021-02-08 16:15:153362ブラウズ

次のチュートリアル コラムでは、thinkphp による、高同時実行下での ThinkPHP5 とフレームレス コードの効率の比較を紹介します。

高同時実行下での ThinkPHP5 とフレームワークレス コードの効率を比較する

ビジネス ロジックのテスト: 宝くじ関数をテストし、MySQL データベースの楽観的ロック メカニズムを使用して過剰発行を防ぎます。

キー コード:

$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),
        );

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

フレームワーク コードなし:

$sql = "select * from `lottory` where id=".$level." ";
     $res = $rnpdo->RnFetchRow($sql, array());
     $dataNum = $res[&#39;errmsg&#39;][&#39;prizenum&#39;];    //剩余数量
     $version = $res[&#39;errmsg&#39;][&#39;version&#39;];    //版本号
     
     $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[&#39;errmsg&#39;])) {
         //插入抽奖记录
         $openid = $version.&#39;-&#39;.createOpenid();
         $time = time();
         $insertSql = "insert into `lottory_list` ( `openid`, `prize`, `posttime`) values (&#39;$openid&#39;,&#39;$level&#39;,&#39;$time&#39;) ";
         $rnpdo->RnPtmQuery($insertSql, array());
         
         echo &#39;success&#39;;
     }
     else
     {
         echo &#39;fail&#39;;
     }

thinkPHP5 コード部分を使用:

$res = Db::table("lottory")->where(&#39;id&#39;,$level)->find();
         
         $dataNum = $res[&#39;prizenum&#39;];    //剩余数量
         $version = $res[&#39;version&#39;];    //版本号
         dump($res);
         
         $result = Db::table(&#39;lottory&#39;)->where(&#39;id&#39;, $level)->where(&#39;version&#39;, $version)->update([&#39;prizenum&#39; => [&#39;exp&#39;,&#39;prizenum-1&#39;],&#39;version&#39; => [&#39;exp&#39;,&#39;version+1&#39;]]);
         dump($result);
         if($result) {
             //插入抽奖记录
             $openid = $version.&#39;-&#39;.createOpenid();
             $time = time();
             $data = [&#39;openid&#39; => $openid, &#39;prize&#39; => $level,&#39;posttime&#39;=>$time];
             Db::table(&#39;lottory_list&#39;)->insert($data);
             
             echo &#39;success&#39;;
         }
         else
         {
             echo &#39;fail&#39;;
         }

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: 1 秒あたりのリクエスト: 972.21 [#/秒] (平均)

thinkPHP5: 1 秒あたりのリクエスト: 206.92 [#/秒] (意味)

フレームワークなしの同じビジネス ロジックは tp5 の 4.7 倍です。

TP5 で最適化されていないものがあるかどうかはわかりませんが、どちらのページ コードもキャッシュを使用していません。

あなたは tp5 について深く理解していますか?何かアドバイスをいただけますか?他に最適化する必要がある領域はありますか?


以上が高同時実行下での ThinkPHP5 とフレームワークレス コードの効率を比較するの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事はoschina.netで複製されています。侵害がある場合は、admin@php.cn までご連絡ください。