介绍php7和php5对比
时间:2022-02-11 13:41
推荐(免费):PHP7 PHP7刚出道就号称比旧版本快了几倍,各种开源框架或系统运行在PHP7上速度效率提高了几倍,反正不管是媒体还是开发者都在煽风点火,不,应该是赞不绝口。 一般手机系统升级我是跑最后的,因为不愿意踩坑,毕竟iOS和Android这种系统都会出现bug,何况世界上被人黑的最多的语言。 今日时机已到,看看PHP7有没有传说的那么王炸。 安装两个PHP版本 http://php.net/ 已经有最新PHP7的最新版本,大家可自行下载。 安装过程就略过了,无论源码安装还是包管理工具安装,记得自己的路径即可。 PHP7: PHP5: 环境说明:为了保证最佳的测试效果,本次测试在直接在生产环境进行,更逼近真实情况。 PHP7和PHP5的对决 1. 纯php脚本测试 PHP5版本测试: PHP7版本测试: 通过数据可以看出来,单纯的php脚本测试,可以看出php7性能提升了3到4倍。 2.php数据库操作测试 首先我们创建一个用户表: 给test_user表插入一条数据: 创建数据库测试脚本test_db.php,确保你的两个PHP版本都安装了PDO扩展。 我的两个PHP版本已经安装了PDO(不要再使用php_mysql扩展,已经过时了,PHP7已经完全抛弃,mysqli也不建议使用)。 接下来我们通过PDO编写脚本,测试select执行50万次的性能对比: PHP5测试test_db.php: PHP7测试test_db.php: 这次脚本执行了50w次查询,user执行时间PHP7执行的脚本几乎都比PHP5要少一秒!是少一秒不是一毫秒。 3.PHP框架测试 thinkphp 国内肯定是首选thinkphp框架,选择最新的thinkphp5。我这里直接在官网下载的thinkphp5.0.9版本。 (一)框架入口测试 PHP5下的测试: PHP7下的测试: 在入口测试下,可以看到PHP和PHP7没有太大的区别,但PHP7还是稍微快一点。 (二)框架逻辑测试 PHP5版本: PHP7版本: 在thinkphp框架中使用PHP7版本,性能提升大约是PHP5版本的4倍! laravel 然后我们测试下现在最火热的PHP艺术家的框架。 (一) 框架入口测试 PHP版本 我们可以看到laravel的框架入口测试中,PHP5和PHP7的表现差异不大,但即使PHP5最高快的0.081s也比PHP7版本最慢的0.067s要慢。所以PHP7还是更胜一筹。 (二)框架逻辑测试 在index方法中写入测试逻辑: PHP5版本 PHP7版本 PHP7性能提升了3到4倍 压力测试 1000个请求,50个并发 PHP5版本: 三次样本如下: PHP7版本: 通过压力测试,在PHP7版本下,可以看到单个请求时间和请求完成时间以及每个连接请求实际运行时间的平均值都耗时更少,最重要的性能指标QPS也是高于PHP5的版本。 PHP7的opcache性能测试 开启opcache: 卧槽!开启了opcache的PHP7果然是要起飞的节奏,相比未开启的PHP7性能提升了十几倍,相比PHP5提升了将进20倍!问你怕不怕! PHP脚本测试数据如下: PHP7 vs PHP5 纯php脚本测试过程,PHP7性能大约是PHP5的3到4倍。 压力测试数据如下: PHP5 vs PHP7 vs PHP7+OPCACHE 结论: 本文对PHP7和PHP5进行简单对比,性能确实有3到4倍提升,无论是在php纯脚本中,还是在框架中,PHP7高性能的表现都是一致的。 PHP7很快,PHP7+OpCache飞快,PHP7确实牛逼,PHP的新时代已来临,赶紧用起来! 以上就是介绍php7和php5对比的详细内容,更多请关注gxlsystem其它相关文章!
我就静静看你们装逼,不说话。
为了测试PHP5和PHP7(PHP6已被放弃,心疼1s)的性能,我在不同的目录安装了两个php版本。# /usr/local/php7/bin/php -vPHP 7.1.5 (cli) (built: May 13 2017 23:36:41) ( NTS )Copyright (c) 1997-2017 The PHP GroupZend Engine v3.1.0, Copyright (c) 1998-2017 Zend Technologies
# /usr/bin/php -vPHP 5.6.30 (cli) (built: Jan 19 2017 22:31:39)Copyright (c) 1997-2016 The PHP GroupZend Engine v2.6.0, Copyright (c) 1998-2016 Zend Technologies
操作系统:CentOS 7.2 64位
基础配置:1核 1GB 1Mbps
主机品牌:腾讯云vim test.php
$arr = array();for ($i = 0; $i < 500000; $i++) {$arr[$i] = $i;}$tmp = array();foreach ($arr as $i) {if ($i % 2 == 0) {$is_exists = array_key_exists($i, $arr);if ($is_exists) {array_push($tmp, $i);}}}
time /usr/bin/php test.php real 0m0.301suser 0m0.239ssys 0m0.050s--------------------------time /usr/bin/php test.phpreal 0m0.310suser 0m0.241ssys 0m0.054s--------------------------time /usr/bin/php test.phpreal 0m0.289suser 0m0.238ssys 0m0.050s
time /usr/local/php7/bin/php test.phpreal 0m0.087suser 0m0.063ssys 0m0.024s-------------------------------------time /usr/local/php7/bin/php test.phpreal 0m0.106suser 0m0.073ssys 0m0.033s--------------------------------------time /usr/local/php7/bin/php test.phpreal 0m0.083suser 0m0.061ssys 0m0.022s
Table: test_userCreate Table: CREATE TABLE `test_user` (`uid` int(11) NOT NULL AUTO_INCREMENT,`name` char(100) NOT NULL DEFAULT '',PRIMARY KEY (`uid`)) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8
insert into test_user (uid,name) values (1,"dada");MariaDB [test]> select * from test_user;+-----+------+| uid | name |+-----+------+| 1 | dada |+-----+------+
/usr/bin/php -m|grep pdopdo_mysqlpdo_sqlite/usr/local/php7/bin/php -m|grep pdopdo_mysqlpdo_sqlite
$host = "yourHost";$user = "yourUser";$pass = "yourPass";$db = "test";$port = 3306;try{$dbh = new PDO("mysql:host=$host;dbname=$db", $user, $pass);echo "Connected<p>";}catch (Exception $e){echo "Unable to connect: " . $e->getMessage() ."<p>";}$sql = "select SQL_NO_CACHE * from test_user;";$tmp = array();for ($i=1; $i<=500000; $i++) {$ret = $dbh->query($sql);foreach ($ret as $row) {$tmp['id'] = $row['id'];$tmp['name'] = $row['name'];}}
time /usr/bin/php test_db.phpreal 0m48.396suser 0m11.149ssys 0m3.998sreal 0m51.447suser 0m11.800ssys 0m4.395sreal 0m51.517suser 0m11.733ssys 0m4.439s
real 0m47.900suser 0m9.875ssys 0m4.130sreal 0m46.977suser 0m9.760ssys 0m3.983sreal 0m50.010suser 0m10.268ssys 0m4.307s
time /usr/bin/php ./public/index.phpreal 0m0.036suser 0m0.026ssys 0m0.010sreal 0m0.038suser 0m0.026ssys 0m0.012sreal 0m0.041suser 0m0.032ssys 0m0.009s
time /usr/local/php7/bin/php ./public/index.phpreal 0m0.027suser 0m0.021ssys 0m0.005sreal 0m0.027suser 0m0.018ssys 0m0.009sreal 0m0.025suser 0m0.023ssys 0m0.002s
在框架入口复用第一步的逻辑:<?phpnamespace app\index\controller;class Index{public function index(){$arr = array();for ($i = 0; $i < 500000; $i++) {$arr[$i] = $i;}$tmp = array();foreach ($arr as $i) {if ($i % 2 == 0) {$is_exists = array_key_exists($i, $arr);if ($is_exists) {array_push($tmp, $i);}}}}}
time /usr/bin/php ./public/index.phpreal 0m0.538suser 0m0.463ssys 0m0.072sreal 0m0.454suser 0m0.386ssys 0m0.065sreal 0m0.387suser 0m0.331ssys 0m0.055s
time /usr/local/php7/bin/php ./public/index.phpreal 0m0.150suser 0m0.123ssys 0m0.024sreal 0m0.137suser 0m0.105ssys 0m0.031sreal 0m0.123suser 0m0.096ssys 0m0.026s
PHP5版本:time /usr/bin/php ./public/index.phpreal 0m0.104suser 0m0.081ssys 0m0.022sreal 0m0.148suser 0m0.122ssys 0m0.025sreal 0m0.122suser 0m0.100ssys 0m0.021s
time /usr/local/php7/bin/php ./public/index.phpreal 0m0.079suser 0m0.064ssys 0m0.015sreal 0m0.081suser 0m0.067ssys 0m0.014sreal 0m0.067suser 0m0.054ssys 0m0.013s
尝试增加一点逻辑,和thinkphp一样,复用测试逻辑。
首先修改laravel路由,直接调用UserController的index方法:Route::get('/', 'UserController@index');
public function index(){$arr = array();for ($i = 0; $i < 500000; $i++) {$arr[$i] = $i;}$tmp = array();foreach ($arr as $i) {if ($i % 2 == 0) {$is_exists = array_key_exists($i, $arr);if ($is_exists) {array_push($tmp, $i);}}}}
time /usr/bin/php ./public/index.phpreal 0m0.510suser 0m0.377ssys 0m0.079sreal 0m0.627suser 0m0.447ssys 0m0.091sreal 0m0.519suser 0m0.436ssys 0m0.079s
time /usr/local/php7/bin/php ./public/index.phpreal 0m0.201suser 0m0.167ssys 0m0.032sreal 0m0.216suser 0m0.174ssys 0m0.040sreal 0m0.169suser 0m0.134ssys 0m0.034s