Vergleichen Sie die Effizienz von ThinkPHP5 und Framework-freiem Code bei hoher Parallelität

藏色散人
Freigeben: 2021-02-08 16:15:15
nach vorne
3314 Leute haben es durchsucht

Die folgende Tutorial-Kolumne von thinkphp wird Ihnen den Vergleich der Effizienz von ThinkPHP5 und rahmenlosem Code bei hoher Parallelität vorstellen. Ich hoffe, dass es für Freunde in Not hilfreich sein wird!

Vergleichen Sie die Effizienz von ThinkPHP5 und Framework-freiem Code bei hoher Parallelität

Getestete Geschäftslogik: Testen Sie eine Lotteriefunktion und nutzen Sie den optimistischen Sperrmechanismus der MySQL-Datenbank, um eine Überausgabe zu verhindern.

Schlüsselcode:

$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;
            }
        }
Nach dem Login kopieren

Kein Framework-Code:

$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;;
     }
Nach dem Login kopieren

Verwenden Sie den thinkPHP5-Codeteil:

$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;;
         }
Nach dem Login kopieren

Verwenden Sie ab, um die Leistung bei hoher Parallelität zu testen:

ab -c 1000 -n 10000 http://localhost/lottory.php
ab -c 1000 -n 10000 http://localhost/index.php?s=index/index/hello
Nach dem Login kopieren

Der Test erfolgt auf demselben Server, der Webserver verwendet Nginx. und TP5 wird abgebrochen. Protokollschreiben (nicht zum ersten Mal entfernt, QPS ist niedriger).

Die Eckdaten:

Frameless QPS: Anfragen pro Sekunde: 972,21 [#/s] (Mittelwert)

thinkPHP5: Anfragen pro Sekunde: 206,92 [#/s] (Mittelwert)

Gleiche Geschäftslogik, kein Frame ist das 4,7-fache von TP5.

Ich weiß nicht, ob es Bereiche gibt, in denen TP5 nicht optimiert wurde.

Haben Sie ein tiefes Verständnis von tp5 und können Sie einige Hinweise geben? Gibt es weitere Bereiche, die optimiert werden müssen?


Das obige ist der detaillierte Inhalt vonVergleichen Sie die Effizienz von ThinkPHP5 und Framework-freiem Code bei hoher Parallelität. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
Quelle:oschina.net
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage