PHP7正式版測試,性能驚豔!

本週迎來2015年編程語言界的兩件大事,Swift 開源, PHP7 發佈。這兩件大事,都是能夠載入相應的編程語言的史冊級的事件。javascript

Swift 開源的事,咱先不說了,知乎上也有熱烈的討論,咱們今天就來看一下PHP 7正式版的算法和 wordpress 應用在其上的性能表現。php

PHP7 的安裝,真是很是地向下兼容,下載,解壓,把以前的配置命令用上,一路回車下去,毫無違和感。爲了避免影響現有的環境的運行,全部專門開闢了目錄 。java

配置參數以下:mysql

--prefix=/usr/local/php7 --with-config-file-path=/usr/local/php7/etc --enable-fpm --with-fpm-user=www --with-fpm-group=www --with-mysqli --with-pdo-mysql --with-iconv-dir --with-freetype-dir --with-jpeg-dir --with-png-dir --with-zlib --with-libxml-dir=/usr --enable-xml --disable-rpath --enable-bcmath --enable-shmop --enable-sysvsem --enable-inline-optimization --with-curl --enable-mbregex --enable-mbstring --with-mcrypt --enable-ftp --with-gd --enable-gd-native-ttf --with-openssl --with-mhash --enable-pcntl --enable-sockets --with-xmlrpc --enable-zip --enable-soap --without-pear --with-gettext --disable-fileinfo --enable-maintainer-zts

GCC 版本
據鳥哥建議,使用新一點的編譯器, 推薦 GCC 4.8以上, 由於只有 GCC 4.8以上 PHP 纔會開啓 Global Register for opline and execute_data 支持, 這個會帶來5%左右的性能提高。因此本實驗選用的 GCC 版本爲gcc version 4.8.2 20131212 (Red Hat 4.8.2-8) (GCC)。算法

安裝好以後,作上軟連接:sql

ln -s /usr/local/php7/bin/php /usr/bin/php7
ln -s /usr/local/php7/bin/php-config /usr/bin/php7-config 
ln -s /usr/local/php7/bin/phpize /usr/bin/php7ize
ln -s /usr/local/php7/sbin/php-fpm /usr/sbin/php7-fpm

php7 -v 看到了咱們熟悉的提示:編程

[root@localhost test]# php7 -v
PHP 7.0.0 (cli) (built: Dec  2 2015 19:19:14) ( ZTS )
Copyright (c) 1997-2015 The PHP Group
Zend Engine v3.0.0, Copyright (c) 1998-2015 Zend Technologies

首先作的是性能評測,評測機型,首都在線雲主機,4核 CPU Intel(R) Xeon(R) CPU E5-2680 0 @ 2.70GHz,內存4G,操做系統 Centos 6.5。後端

隨便寫了三段程序:數組

第一段,生成一個 60 萬元素的數組,經過查找key 的方式,來肯定key是否存在。服務器

<?php
$a = array();
for($i=0;$i<600000;$i++){
        $a[$i] = $i;
}

foreach($a as $i)
{
    array_key_exists($i, $a);
}

首先是 PHP 5.3.17 版。

[root@localhost test]# time php search_by_key.php 
real    0m0.389s
user    0m0.337s
sys     0m0.051s
[root@localhost test]# time php search_by_key.php 
real    0m0.378s
user    0m0.308s
sys     0m0.062s
[root@localhost test]# time php search_by_key.php 
real    0m0.378s
user    0m0.317s
sys     0m0.061s

其次是 PHP7 版。

[root@localhost php7]#  time php7 search_by_key.php
real    0m0.082s
user    0m0.066s
sys     0m0.014s
[root@localhost php7]#  time php7 search_by_key.php
real    0m0.080s
user    0m0.058s
sys     0m0.021s
[root@localhost php7]#  time php7 search_by_key.php
real    0m0.080s
user    0m0.053s
sys     0m0.026s`

這剛出手,就名不虛傳,響應時間在PHP7下運行變爲原來的1/4。真牛!
那我還得搞倆試試,第二段,仍是上面的這個方式,不過因爲速度較慢,因此變成了一個60000個元素的數組,查找值。
代碼以下:
php代碼:

<?php
$a = array();
for($i=0;$i<600000;$i++){
        $a[$i] = $i;
}

foreach($a as $i)
{
    array_key_exists($i, $a);
}
[root@localhost test]# time php search_by_val.php 
real    0m24.296s
user    0m24.184s
sys     0m0.025s
[root@localhost test]# time php search_by_val.php 
real    0m25.523s
user    0m25.317s
sys     0m0.026s
[root@localhost test]# time php search_by_val.php 
real    0m26.026s
user    0m25.478s
sys     0m0.092s

等待的時間,老是以爲很漫長,三次測試,花掉了75秒多。下面,PHP 7 登場了。

[root@localhost php7]#  time php7 search_by_val.php
real    0m3.362s
user    0m3.323s
sys     0m0.007s
[root@localhost php7]#  time php7 search_by_val.php
real    0m3.266s
user    0m3.251s
sys     0m0.004s
[root@localhost php7]#  time php7 search_by_val.php
real    0m3.290s
user    0m3.275s
sys     0m0.006s

吊咋天,有沒有!速度整整提升了將近7倍。
筆者激動的心情難以言表,順手又整了一個比較高效的素數算法。算出2000000之內的素數的數目,此次我們 PHP7先開始。

[root@localhost php7]#  time php7 prime_v3.php 2000000
real    0m1.151s
user    0m1.129s
sys     0m0.010s
[root@localhost php7]#  time php7 prime_v3.php 2000000
real    0m1.141s
user    0m1.123s
sys     0m0.011s
[root@localhost php7]#  time php7 prime_v3.php 2000000
real    0m1.145s
user    0m1.128s
sys     0m0.010s`

速度穩定在 1.2 S
而 PHP 5.3 呢,此次比上一次的差距小點了,可是PHP7速度也是它的3倍到4倍之間。

[root@localhost test]# time php prime_v3.php 2000000
prime number count under 2000000 is :148933
real    0m4.425s
user    0m4.380s
sys     0m0.023s
[root@localhost test]# time php prime_v3.php 2000000
prime number count under 2000000 is :148933
real    0m4.457s
user    0m4.414s
sys     0m0.032s
[root@localhost test]# time php prime_v3.php 2000000
prime number count under 2000000 is :148933
real    0m4.464s
user    0m4.399s
sys     0m0.046s

此素數算法以下,用的是篩選法。相對是運行速度比較快的求素數算法。

<?php
/* 
 * To change this license header, choose License Headers in Project Properties.
 * To change this template file, choose Tools | Templates
 * and open the template in the editor.
 */
$num = $argv[1];
$ret = array(2);
$flag = false;
for($i=3; $i<=$num; $i+=2)
{
    $flag = false;
    $sqrt = sqrt($i);
    foreach($ret as $prime)
    {
        if($i%$prime == 0)
        {
            $flag = true;
            break;
        }
        if($prime>$sqrt)
        {
            break;
        }
    }
     
    if(!$flag)
    {
        $ret[] = $i;
    }
}
echo (count($ret))."\n";

至此,咱們基本能夠說明問題。這些代碼,並無使用複雜的函數庫,也沒有大量的網絡和IO,性能卻獲得了至少3倍以上的優化。這真是一個歷史性的進步。而在咱們過去的性能評測中,語言層面的性能,每每是忽略的,爲何這麼講呢,好比在 XHProf中,就專門有一個選項,XHPROF_FLAGS_NO_BUILTINS,用於對內置的函數或者內部函數不作分析,好比數組、日期等的函數。由於你們每每錯過了這塊的提高空間,固然,通常人也沒法在這塊提高,因此纔有了 HHVM,也激發了今天的PHP 7。

一輪測試下來,激發起了筆者對PHP 7更多瞭解的興趣,想看看擴展和一些常見的框架支持如何,順手作了以下兩個測試。

記得在Alpha1版本的時候,OneAPM是不能支持的,此次行不行呢?筆者拿到 OneApm_php_Agent_1.0.0.18.tar 版,順利安裝。

吊炸天的 PHP 7 ,你值得擁有!

成功地識別了PHP 7的安裝路徑。

吊炸天的 PHP 7 ,你值得擁有!
安裝成功。

對於擴展,我是沒有信心再測下去了,下面測兩個經常使用的東東,一個是Wordpress,雖然網站被和諧了,可是是什麼地球人都知道吧。另一個是ThinkPHP, 這是國內使用量最普遍的PHP開發框架,絕對第一,不是之一。筆者也是TP的粉絲。

是該誇這兩個軟件作得好呢?仍是該誇 PHP 7的兼容作得好呢,我也不知道了,反正筆者看到了初步正常。

Wordpress 後臺,在PHP 7 作爲 FastCGI 後端時,運行正常。

ThinkPHP 最新版本3.2.3 在PHP 7 下運行正常。

最後咱們來作一個壓力測試,兩個wordpress,一個是基本爲空的剛剛安裝的版本,一個是發佈了數篇文章的版本,咱們針對主頁進行測試。分別在PHP5.5和PHP7下進行測試,而且二者都分別打開和關閉Zend OpCache,看看響應性能是否有明顯變化。
一、PHP 5.5.26 無Zend Opcache 有文章版,20個併發

二、PHP 5.5.26 無Zend Opcache 有文章版,10個併發

三、PHP 5.5.26 無Zend Opcache 無文章版,20個併發

四、PHP 5.5.26 無Zend Opcache 無文章版,10個併發

可見併發並無對總時間形成影響,有文章相比無文章,總時長慢了6S,平均慢了20%。
下面咱們打開PHP 5.5.26 的Zend OpCache。
一、PHP 5.5.26 有Zend Opcache 有文章版,20個併發

吊炸天的 PHP 7 ,你值得擁有!

二、PHP 5.5.26 有Zend Opcache 有文章版,10個併發

吊炸天的 PHP 7 ,你值得擁有!

三、PHP 5.5.26 有Zend Opcache 無文章版,20個併發

吊炸天的 PHP 7 ,你值得擁有!

四、PHP 5.5.26 有Zend Opcache 無文章版,10個併發

吊炸天的 PHP 7 ,你值得擁有!

可見,是否開啓Zend OpCache,對性能影響極爲明顯。對有文章版有2倍以上提高,對無文章版有4倍以上提高。

下面咱們來測試PHP7,一樣第一次是無Zend OpCache的版本。
一、PHP 7 無Zend Opcache 有文章版,20個併發

二、PHP 7 無Zend Opcache 有文章版,10個併發

吊炸天的 PHP 7 ,你值得擁有!

從以上數據可見,在PHP7 對比PHP5.5.26有30%左右的性能提高,再來看一下無文章版。
三、PHP7 無Zend Opcache 無文章版,20個併發

吊炸天的 PHP 7 ,你值得擁有!

四、PHP 7 無Zend Opcache 無文章版,10個併發

吊炸天的 PHP 7 ,你值得擁有!

無文章版對比PHP5.5.26有 60%左右的提高。下面再來看一下開啓PHP7下Zend OpCache的版本。
注意PHP7的Zend OpCache 與PHP5不一樣,不須要專門安裝擴展,只須要在php.ini中加入以下三行配置便可。
zend_extension=opcache.so
opcache.enable=1
opcache.enable_cli=1

一、PHP 7 有Zend Opcache 有文章版,20個併發

二、PHP 7 有Zend Opcache 有文章版,10個併發

吊炸天的 PHP 7 ,你值得擁有!

三、PHP 7 有Zend Opcache 無文章版,20個併發

吊炸天的 PHP 7 ,你值得擁有!

四、PHP 7 有Zend Opcache 無文章版,10個併發

吊炸天的 PHP 7 ,你值得擁有!

太無敵了,開啓Zend OpCache,有5倍以上性能提高,而對比一樣開啓Zend OpCache的5.5.26,也至少有3倍以上的性能提高。能夠說Zend OpCache對高併發下的性能至爲關鍵。

PHP7性能的評測就到這裏,從6月份推出PHP7 alpha版以來,咱們很欣喜地等來了PHP7正式版的發佈。再次評測證實,PHP7,值得你的擁有,OneAPM for PHP 可以深刻到全部 PHP 應用內部完成應用性能管理和監控,包括代碼級別性能問題的可見性、性能瓶頸的快速識別與追溯、真實用戶體驗監控、服務器監控和端到端的應用性能管理。而開啓了Zend OpCache 的PHP7和OneAPM,更是值得你來熱烈擁有。

相關文章
相關標籤/搜索