PHP归档phar性能測试
相同,与 JAR 归档不同的是。Phar 归档可由 PHP 本身处理,因此不须要使用额外的工具来创建或使用。Phar 扩展对 PHP 来说并非一个新奇的概念。它最初使用 PHP 编写并被命名为 PHP_Archive。然后在 2005 年被加入到 PEAR 库。
然而在实际中,解决这一问题的纯 PHP 解决方式非常缓慢。因此 2007 年又一次编写为纯 C 语言扩展,同一时候加入了使用 SPL 的 ArrayAccess 对象遍历 Phar 归档的支持。自那时起,人们做了大量工作来改善 Phar 归档的性能,眼下对Phar使用非常有限。而关于Phar的性能測试非常少,究竟Phar性能怎样,通过一个简单实验检验下。
測试环境:
PHP:5.5.10
CPU:2GHz intel core i7
Mem:8GB
系统:Darwin 13.1.0
主要測试点:
1:Phar载入速度
1.1:文件大小多少的影响?
1.2: include/require的影响?
1.3:Phar 存根(Stub)内容的影响?
2:Phar代码运行速度
2.1 全局函数对照
2.2 类对象
2.3 类方法
为了保证尽量保证測试准确。每种方式运行3次,去3次的平均值。
同一时候作为对照,我们会直接採用代码方式,获得基准数据。
Phar 文件主要包括文件
phar-builder.php用于生成phar文件。运行test命令前,先运行此文件生成phar-test.phar文件。
test_load.php 測试载入phar文件速度
src文件夹内包括文件index.php文件是存根文件。包括dates.php,for.php,functions.php,dates測试文件类方法,for.php測试对象方法。functions.php測试函数方法。
详细附件代码。
第一:phar载入速度,採用include和require方式測试发现差异不大。仅仅採用require方式。
$stime = microtime(true);
require './phar-test.phar';
$etime = microtime(true);
$total = $etime - $stime;
echo "phar total:".$total."s";
运行后,效率例如以下
localhost:phar ugg$ php test_phar_load.php
phar total:0.0044760704040527s
localhost:phar ugg$ php test_phar_load.php
phar total:0.0051448345184326s
localhost:phar ugg$ php test_phar_load.php
phar total:0.0043849945068359s
localhost:phar ugg$ vim test_phar_load.php
平均载入4.7毫秒
对照直接源码引用方式。
$stime = microtime(true);
require './src/index.php';
$etime = microtime(true);
$total = $etime - $stime;
echo "src total:".$total."s\n";
运行后,效率例如以下
localhost:phar ugg$ php test_src_load.phpsrc
total:0.0026230812072754s
localhost:phar ugg$ php test_src_load.phpsrc
total:0.0026969909667969s
localhost:phar ugg$ php test_src_load.phpsrc
total:0.0025439262390137s
平均载入2.6毫秒
结论:通过载入速度对照。phar载入方式比直接文件载入方式慢了不少。差点儿直接引用文件所耗时间的两倍。同一时候我又在phar文件里载入一些干扰文件,使phar文件变大。发如今10k以内,这个load时间变化不大。
当然我并没有把新增的文件放到存根内,这样做的目的,对于超过10K的文件夹。文件组织方式比方是autoload方式,而不会通过一个文件包括全部的文件。phar载入时间是src直接载入的1.8倍左右。
第二:运行速度检验
phar方式,代码例如以下
$stime = microtime(true);
//require 'phar://phar-test.phar';
require 'phar-test.phar';
$sstime = microtime(true);
for($i = 0; $i<10000; ++$i){
$date = dates::next_week();
$for = new fortest();
$i = $for->for1to10000();
$number = number2Chinese('12345');
}
$eetime = microtime(true);
$etime = microtime(true);
$total = $etime - $stime;
$total2 = $eetime - $sstime;
echo "phar load total:".$total."s\n";
echo "phar execution 10000 total:".$total2."s";
运行效率例如以下
localhost:phar ugg$ php test_phar_functions.php
phar load total:0.0047600269317627s
phar execution 10000 total:0.00017499923706055s
localhost:phar ugg$ php test_phar_functions.php
phar load total:0.004863977432251s
phar execution 10000 total:0.00017404556274414s
localhost:phar ugg$ php test_phar_functions.php
phar load total:0.004680871963501s
phar execution 10000 total:0.00016689300537109s
运行10000次的类方法,对象实例和对象方法,以及函数方法,总共时间消耗为0.17毫秒。
src运行效率
localhost:phar ugg$ php test_src_functions.php
phar load total:0.0029089450836182s
phar execution 10000 total:0.00019693374633789s
localhost:phar ugg$ php test_src_functions.php
phar load total:0.0028579235076904s
phar execution 10000 total:0.0002140998840332s
localhost:phar ugg$ php test_src_functions.php
phar load total:0.0029168128967285s
phar execution 10000 total:0.00019478797912598s
运行10000次的类方法,对象实例和对象方法,以及函数方法,总共时间消耗为0.20毫秒。
小结:通过运行速度对照。发现是phar方式,运行速度。要比直接文件include方式,快了(0.20-0.17)/0.20*100=15%,phar方式运行速度快的详细原因没有找到。网上有份资料,apc+include_path设置 phar运行速度非常快。
https://github.com/ralphschindler/test-phar-performance-apc/。
总结:PHP归档phar方式,载入速度要慢于正常文件包括方式。可是运行速度要高于文件包括方式。假设配合include_path设置和APC或者OP方式。优化phar归档的载入速度。就能提升php的运行速度。下一步会做方面的尝试,1:构建大phar文件,实验载入速度,运行速度。2:了解phar载入原理和运行原理,3:包概念管理和依赖。
其它一些參考资料
PHP V5.3中新特性,创建并使用Phar归档。http://www.ibm.com/developerworks/cn/opensource/os-php-5.3new4/
test-phar-performance-apc https://github.com/ralphschindler/test-phar-performance-apc/
PHP归档phar性能測试的更多相关文章
- mongodb3.0 性能測试报告 一
mongodb3.0 性能測试报告 一 mongodb3.0 性能測试报告 二 mongodb3.0 性能測试报告 三 測试环境: 服务器:X86 pcserver 共6台 cpu: 单颗8核 ...
- Window平台搭建Redis分布式缓存集群 (一)server搭建及性能測试
百度定义:Redis是一个key-value存储系统.和Memcached类似,它支持存储的value类型相对很多其它.包含string(字符串).list(链表).set(集合).zset(sort ...
- mysql主键设置成auto_increment时,进行并发性能測试出现主键反复Duplicate entry 'xxx' for key 'PRIMARY'
mysql主键设置成auto_increment时,进行并发性能測试出现主键反复Duplicate entry 'xxx' for key 'PRIMARY' 解决方法: 在my.cnf的[mysql ...
- 系统吞吐量、TPS(QPS)、用户并发量、性能測试概念和公式
PS:以下是性能測试的主要概念和计算公式,记录下: 一.系统吞度量要素: 一个系统的吞度量(承压能力)与request对CPU的消耗.外部接口.IO等等紧密关联.单个reqeust 对CPU消耗越高, ...
- Linux 性能測试工具
Linux 性能測试工具 linux performance 查看系统配置 查看CPU信息 lscpu Architecture: x86_64 CPU op-mode(s): 32-bit, 64- ...
- LR杂记 - 性能測试指标及经常使用的监控工具
监控指标 性能測试通常须要监控的指标包含: 1.serverLinux(包含CPU.Memory.Load.I/O). 2.数据库:1.Mysql 2.Oracle(缓存命中.索引.单条SQL性能.数 ...
- Redis源代码分析(十三)--- redis-benchmark性能測试
今天讲的这个是用来给redis数据库做性能測试的,说到性能測试,感觉这必定是高大上的操作了.redis性能測试.測的究竟是哪方面的性能,怎样測试,通过什么指标反映此次測试的性能好坏呢.以下我通过源代码 ...
- 微博达人硅谷之歌:Testin云測移动搜索性能測试非常是让人信服
微博达人硅谷之歌:Testin云測移动搜索性能測试非常是让人信服 2014/10/08 · Testin · 开发人员訪谈 2013年11月1日,谷歌运行董事长施密特(Eric Emerson Sch ...
- mongodb3.0 性能測试报告 二
mongodb3.0 性能測试报告 一 mongodb3.0 性能測试报告 二 mongodb3.0 性能測试报告 三 測试环境: 服务器:X86 pcserver 共6台 cpu: 单颗8核 ...
随机推荐
- shiro配置unauthorizedUrl,无权限抛出无权限异常,但是不跳转
在使用shiro配置无授权信息的url的时候,发现这样的一个scenario,配置好unauthorizedUrl后仍然无法跳转,然后就在网上开始找,找了原因以及解决方案 原因,先post一个源码: ...
- 线段树 + 字符串Hash - Codeforces 580E Kefa and Watch
Kefa and Watch Problem's Link Mean: 给你一个长度为n的字符串s,有两种操作: 1 L R C : 把s[l,r]全部变为c; 2 L R d : 询问s[l,r]是 ...
- Windows 安装、重装MySQL时,报错:could not start the service mysql
原因: 卸载mysql时并没有完全删除相关文件和服务,需要手动清除. 解决方法: 首先,在管理工具->服务里面将MySQL的服务给停止(有的是没有安装成功,有这个服务,但是已经停止了的). 然后 ...
- 在MFC中改变控件的TAB顺序
在MFC界面中,控件的TAB顺序如果乱了,不合理,可能会使界面出现意料之外的显示. 例如,在用Spin Control来对Edit Control内的值进行增减时,如果Edit Control.Spi ...
- MyBitis(iBitis)系列随笔之六:mybitis与spring集成
目前Spring官方还没有出整合Mybatis的特性,但是mybitis比较给力,开发了一个mybatis-spring插件,达到与Spring的完美整合目的. 在与Spring集成前,一方面我们需要 ...
- Asp.net中的Cache--HttpRuntim.Cache 和 HttpContext.Current.Cache
在ASP.NET中有两个类都提供缓存支持, 一个是HttpRuntime类的Cache属性, 另一个是HttpContext类的Cache属性. 通过查看这两个属性的类型可以发现其实这两个属性都是Sy ...
- Margin外边距叠加
外边距(Margin)叠加 只有普通文档流中块级元素(块框)的垂直外边距才会发生外边距叠加.行内框.浮动框和绝对定位框之间的外边距不会叠加 两个相邻兄弟块框 父元素与子元素,并 父元素没有内边距或边框 ...
- Angular 组件与模板 - 属性指令
指令概览 在 Angular 中有三种类型的指令: 组件 — 拥有模板的指令 结构型指令 — 通过添加和移除 DOM 元素改变 DOM 布局的指令 属性型指令 — 改变元素.组件或其它指令的外观和行为 ...
- linux 常用命令总结(tsg)
1.解压tar.gz 第一步:gunzip filename.tar.gz --->会解压成.tar文件 第二步:tar xvf FileName.tar ---->会解压到当前文件夹2. ...
- shell脚本学习总结04--终端信息的获取和设置
tput tput 命令将通过 terminfo 数据库对您的终端会话进行初始化和操作.通过使用 tput,您可以更改几项终端功能,如移动或更改光标.更改文本属性,以及清除终端屏幕的特定区域. 文本属 ...