ホームページ > 記事 > PHPフレームワーク > 高同時実行下での ThinkPHP5 とフレームワークレス コードの効率を比較する
次のチュートリアル コラムでは、thinkphp による、高同時実行下での 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]['randnum']) { $level = $prizeArr[$i]['level']; break; } }
フレームワーク コードなし:
$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: 1 秒あたりのリクエスト: 972.21 [#/秒] (平均)
thinkPHP5: 1 秒あたりのリクエスト: 206.92 [#/秒] (意味)
フレームワークなしの同じビジネス ロジックは tp5 の 4.7 倍です。
TP5 で最適化されていないものがあるかどうかはわかりませんが、どちらのページ コードもキャッシュを使用していません。
あなたは tp5 について深く理解していますか?何かアドバイスをいただけますか?他に最適化する必要がある領域はありますか?
以上が高同時実行下での ThinkPHP5 とフレームワークレス コードの効率を比較するの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。