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';
}
thinkphp3else
{
echo 'fail';
}
使⽤ab测试⾼并发下的表现:
测试在同⼀服务器上,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了解深的指导⼀下,是否还有其它地⽅要优化?

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。