深度探讨PHP之性能

 

1.缘起

关于PHP,很多人的直观感觉是PHP是一种灵活的脚本语言,库类丰富,使用简单,安全,非常适合WEB开发,但性能低下。PHP的性能是否真的就 如同大家的感觉一样的差呢?本文就是围绕这么一个话题来进行探讨的。从源码、应用场景、基准性能、对比分析等几个方面深入分析PHP之性能问题,并通过真 实的数据来说话。

2.从原理分析PHP性能

从原理分析PHP的性能,主要从以下几个方面:内存管理、变量、函数、运行机制来进行分析。

2.1内存管理

类似Nginx的内存管理方式,PHP在内部也是基于内存池,并且引入内存池的生命周期概念。在内存池方面,PHP对PHP脚本和扩展的所有内存相关操作都进行了托管。对大内存和小内存的管理采用了不同的实现方式和优化,具体可以参考以下文档:https://wiki.php.net/internals/zend_mm。在内存分配和回收的生命周期内,PHP采用一次初始化申请+动态扩容+内存标识回收机制,并且在每次请求结束后直接对内存池进行重新mask。

2.2变量

总所周知,PHP是一种弱变量类型的语言,所以在PHP内部,所有的PHP变量都对应成一种类型Zval,其中具体定义如下:

图一PHP变量

在变量方面,PHP做了大量的优化工作,比如说Reference counting和copy on writer机制。这样能够保证内存使用上的优化,并且减少内存拷贝次数(请参考http://blog.xiuwz.com/2011/11/09 /php-using-internal-zval/)。在数组方面,PHP内部采用高效的hashtable来实现。

2.3函数

在PHP内部,所有的PHP函数都回转化成内部的一个函数指针。比如说扩展中函数


  1. 		ZEND_FUNCTION ( my_function );//类似function my_function(){}  

在内部展开后就会是一个函数


  1. 		void zif_my_function ( INTERNAL_FUNCTION_PARAMETERS );  
  2. void zif_my_function(  
  3. int ht,  
  4. zval * return_value,  
  5. zval * this_ptr,  
  6. int return_value_used,  
  7. zend_executor_globals * executor_globals  
  8. );   
  9.  

从这个角度来看,PHP函数在内部也是对应一个函数指针。

2.4运行机制

在话说PHP性能的时候,很多人都会说“C/C++是编译型,JAVA是半编译型,PHP是解释型”。也就是说PHP是先动态解析再代码运行的,所以从这个角度来看,PHP性能必然很差。

的确,从PHP脚本运行来输出,的确是一个动态解析再代码运行的过程。具体来说,PHP脚本的运行机制如下图所示:

图二 PHP运行机制

PHP的运行阶段也分成三个阶段:

  • Parse。语法分析阶段。
  • Compile。编译产出opcode中间码。
  • Execute。运行,动态运行进行输出。

所以说,在PHP内部,本身也是存在编译的过程。并且据此产生了大量的opcode cache工具,比如说apc、eacc、xcache等等。这些opcode cache在生产环境基本上在标配。基于opcode cache,能到做到“PHP脚本编译一次,多次运行”的效果。从这点上,PHP就和JAVA的半编译机制非常类似。

所以,从运行机制上来看,PHP的运行模式和JAVA是非常类似的,都是先产生中间码,然后运行在不同虚拟机上。

2.5动态运行

从上面的几个分析来看,PHP在内存管理、变量、函数、运行机制等几个方面都做了大量的工作,所以从原理来看,PHP不应该存在性能问题,性能至少也应该和Java比较接近。

这个时候就不得不谈PHP动态语言的特性所带来的性能问题了,由于PHP是动态运行时,所以所有的变量、函数、对象调用、作用域实现等等都是在执行 阶段中才确定的。这个从根本上决定了PHP性能中很难改变的一些东西:在C/C++等能够在静态编译阶段确定的变量、函数,在PHP中需要在动态运行中确 定,也就决定了PHP中间码不能直接运行而需要运行在Zend Engine上。

说到PHP变量的具体实现,又不得不说一个东西了:Hashtable。Hashtable可以说在PHP灵魂之一,在PHP内部广泛用到,包含变量符号栈、函数符号栈等等都是基于hashtable的。

以PHP变量为例来说明下PHP的动态运行特点,比如说代码:


  1. 		<?php 
  2. $var = “hello, blog.xiuwz.com”;  
  3. ?>   
  4.  

该代码的执行结果就是在变量符号栈(是一个hashtable)中新增一个项

当要使用到该变量时候,就去变量符合栈中去查找(也就是变量调用对出了一个hash查找的过程)。

同样对于函数调用也基本上类似有一个函数符号栈(hashtable)。

其实关于动态运行的变量查找特点,在PHP的运行机制中也能看出一些。PHP代码通过解释、编译后的流程下图:

图3 PHP运行实例

从上图可以看出,PHP代码在compile之后,产出的了类符号表、函数符号表、和OPCODE。在真正执行的时候,zend Engine会根据op code去对应的符号表中进行查找,处理。

从某种程度上,在这种问题的上,很难找到解决方案。因为这是由于PHP语言的动态特性所决定的。但是在国内外也有不少的人在寻找解决方案。因为通过这样,能够从根本上完全的优化PHP。典型的列子有facebook的hiphop(https://github.com/facebook/hiphop-php)。

2.6结论

从上面分析来看,在基础的内存管理、变量、函数、运行机制方面,PHP本身并不会存在明显的性能差异,但由于PHP的动态运行特性,决定了PHP和 其他的编译型语言相比,所有的变量查找、函数运行等等都会多一些hash查找的CPU开销和额外的内存开销,至于这种开销具体有多大,可以通过后续的基准 性能和对比分析得出。

因此,也可以大体看出PHP不太适合的一些场景:大量计算性任务、大数据量的运算、内存要求很严格的应用场景。如果要实现这些功能,也建议通过扩展的方式实现,然后再提供钩子函数给PHP调用。这样可以减低内部计算的变量、函数等系列开销。

3.基准性能

对于PHP基准性能,目前缺少标准的数据。大多数同学都存在感性的认识,有人认为800QPS就是PHP的极限了。此外,对于框架的性能和框架对性能的影响很没有响应的权威数字。

本章节的目的是给出一个基准的参考性能指标,通过数据给大家一个直观的了解。

具体的基准性能有以下几个方面:

1.裸PHP性能。完成基本的功能。

2.裸框架的性能。只做最简单的路由分发,只走通核心功能。

3.标准模块的基准性能。所谓标准模块的基准性能,是指一个具有完整服务模块功能的基准性能。

3.1环境说明

测试环境:

 


Uname -a

Linux db-forum-test17.db01.baidu.com 2.6.9_5-7-0-0 #1 SMP Wed Aug 12 17:35:51 CST 2009 x86_64 x86_64 x86_64 GNU/Linux

Red Hat Enterprise Linux AS release 4 (Nahant Update 3)

8  Intel(R) Xeon(R) CPU           E5520  @ 2.27GHz

软件相关:

 


Nginx:

nginx version: nginx/0.8.54  built by gcc 3.4.5 20051201 (Red Hat 3.4.5-2)

Php5:(采用php-fpm)

PHP 5.2.8 (cli) (built: Mar  6 2011 17:16:18)

Copyright (c) 1997-2008 The PHP Group

Zend Engine v2.2.0, Copyright (c) 1998-2008 Zend Technologies

with eAccelerator v0.9.5.3, Copyright (c) 2004-2006 eAccelerator, by eAccelerator

bingo2:

PHP框架。

其他说明:

目标机器的部署方式:脚本。

测试压力机器和目标机器独立部署。

3.2裸PHP性能

最简单的PHP脚本。


  1. 		<?php 
  2. require_once ‘./actions/indexAction.php’;  
  3. $objAction = new indexAction();  
  4. $objAction->init();  
  5. $objAction->execute();  
  6. ?> 
  7. Acitons/indexAction.php里面的代码如下  
  8. <?php 
  9. class indexAction  
  10. {  
  11. public function execute()  
  12. {  
  13. echo ‘hello, world!’;  
  14. }  
  15. }  
  16. ?>   
  17.  

通过压力工具测试结果如下:

3.3裸PHP框架性能

为了和3.2的对比,基于bingo2框架实现了类似的功能。代码如下


  1. 		<?php 
  2. require_once ‘Bingo/Controller/Front.php’;  
  3. $objFrontController = Bingo_Controller_Front::getInstance(array(  
  4. ‘actionDir’ => ‘./actions’,  
  5. ));  
  6. $objFrontController->dispatch();  

压力测试结果如下:

从该测试结果可以看出:框架虽然有一定的消耗,但对整体的性能来说影响是非常小的。

3.4标准PHP模块的基准性能

所谓标准PHP模块,是指一个PHP模块所必须要具体的基本功能:

路由分发。

自动加载。

LOG初始化&Notice日志打印。所以的UI请求都一条标准的日志。

  • 错误处理。
  • 时间校正。
  • 自动计算每个阶段耗时开销。
  • 编码识别&编码转化。
  • 标准配置文件的解析和调用

采用bingo2的代码自动生成工具产生标准的测试PHP模块:test。

测试结果如下:

3.5结论

从测试数据的结论来看,PHP本身的性能还是可以的。基准性能完全能够达到几千甚至上W的QPS。至于为什么在大多数的PHP模块中表现不佳,其实 这个时候更应该去找出系统的瓶颈点,而是简单的说OK,PHP不行,那我们换C来搞吧。(下一个章节,会通过一些例子来对比,采用C来处理不见得有特别的 优势)

通过基准数据,可以得出以下几个具体的结论:

1.PHP本身性能也很不错。简单功能下能够达到5000QPS,极限也能过W。

2.PHP框架本身对性能影响非常有限。尤其是在有一定业务逻辑和数据交互的情况下,几乎可以忽略。

3.一个标准的PHP模块,基准性能能够达到2000QPS(80 cpu idle)。

4.对比分析

很多时候,大家发现PHP模块性能不行的时候,就来一句“ok,我们采用C重写吧”。在公司内,采用C/C++来写业务逻辑模块的现象到处都有,在前几年甚至几乎全部都是采用C来写。那时候大家写的真是一个痛苦:调试难、敏捷不要谈。

文章出自:baidu-tech.com

以上是小编为您精心准备的的内容,在的博客、问答、公众号、人物、课程等栏目也有的相关内容,欢迎继续使用右上角搜索按钮进行搜索php
, 内存
, 函数
, 变量
, 性能
, 运行
, php内存管理
, 函数性能
, OpCode原理
, PHP性能优化
, php的运行机制
, php运行机制
, php性能
php动态函数调用
互联网性能问题探讨、深度学习gpu cpu性能、深度学习 高性能、solr 深度分页 性能、深度脱水性能招标文件,以便于您获取更多的相关知识。

时间: 2024-10-30 12:35:37

深度探讨PHP之性能的相关文章

深度探讨 PHP 之性能

1.缘起 关于PHP,很多人的直观感觉是PHP是一种灵活的脚本语言,库类丰富,使用简单,安全,非常适合WEB开发,但性能低下.PHP的性能是否真的就 如同大家的感觉一样的差呢?本文就是围绕这么一个话题来进行探讨的.从源码.应用场景.基准性能.对比分析等几个方面深入分析PHP之性能问题,并通过真 实的数据来说话. 2.从原理分析PHP性能 从原理分析PHP的性能,主要从以下几个方面:内存管理.变量.函数.运行机制来进行分析. 2.1内存管理 类似Nginx的内存管理方式,PHP在内部也是基于内存池

Oracle Freelist和HWM原理探讨及相关性能优化

oracle|性能|优化 Oracle Freelist和HWM原理探讨及相关性能优化 中兴通讯重庆研究所 游波   关键词:Freelist,HWM,存储参数,段,块,dump,优化 文章摘要:    近期来,FreeList的重要作用逐渐为Oracle DBA所认识,网上也出现一些相关的讨论.本文以FreeList为线索对Oracle的存储管理的原理进行较深入的探讨,涉及Oracle段区块管理的原理,FreeList算法等.而与FreeList密切相关的一个重用特性HWM,与sql性能密切相

人工智能深度探讨:智能机器人引领认知革命

导读: 1月18日,由中国人工智能学会.湛庐文化等主办的"智能时代大未来"高峰论坛在上海召开,这是新年以来首场中外人工智能领域专家.学者的深度交流.中国科学院院士何积丰.<纽约时报>高级科技记者.<与机器人共舞>作者约翰·马尔科夫.国家信息中心专家委员会主任宁家骏.国家标委会委员小i机器人创始人兼总裁朱频频发表主题演讲,从国家.学界.商业.发展环境等层面对人工智能的发展,中国面临的机遇与挑战进行了深度探讨. 在此次论坛中,朱频频是唯一身兼行业专家与商业大咖身份的

深度探讨网络攻击给企业带来的商业影响

德勤会计师事务所发现:"隐藏代价"能占到公司总体业务损失的90%,而且极有可能在事发2年后甚至更长时间才会显现出来. 没有人会否认网络攻击的频度和强度都在增加,大多数公司都承认自己至少遭到过1起网络事件.但这些公司真的了解网络事件对公司的全部影响吗?毕竟,数据泄露相关的直接损失通常都远远不及"隐藏代价". 事实上,"隐藏代价"能占到公司总体业务损失的90%,而且极有可能在事发后2年甚至更久后才会显现出来. 这是德勤会计师事务所新近发布的一项研究报

Nervana 开源深度学习软件,性能超 Facebook、Nvidia产品

Nervana System是少数专注机器学习这种人工智能技术的创业公司该公司,近日宣布将其深度学习软件在Apache开源许可协议下开源(github),任何人都可以免费下载使用.根据Facebook一位研究者的基准测试,Nervana的软件比业界知名的深度学习工具性能都要高,包括Facebook自己的Torch7和Nvidia的cuDNN. 深度学习时人工智能技术的热门领域,目前谷歌.微软和百度等互联网巨头在深度学习也都投入重金研发.而不少深度学习创业公司也都遭巨头们纷纷抢购,例如Madbit

live555学习之基本类介绍及计划任务深度探讨

liveMedia项目的源代码包括四个基本的库,各种测试代码以及Media Server.四个基本的库分别是: UsageEnvironment&TaskScheduler, groupsock, liveMedia和BasicUsageEnvironment. 1,基础类介绍: BasicUsageEnvironment和UsageEnvironment中的类都是用于整个系统的基础功能类.用于事件的调度,实现异步读取事件的句柄的设置以及错误信息的输出.比如UsageEnvironment代表了

深度探讨互联网变现与计算广告

刘鹏:大家好,我是老的清华人,诸位都是95后了,你们出生的时候我入学.我在清华电子系呆了十年,04年年底博士毕业,毕业以后在MSRA,师从Frank Soong老师.我接触广告是从08年底,现在京东的副总裁张晨老师刚从美国回来建雅虎的研究院北京分院,我是北京最早的员工之一.雅虎当时是一个很有意思的公司,现在大家拿雅虎不当回事,其实雅虎当时还是很强的,它的市值也曾经超过一千亿美金.并且雅虎有一个特点,它的产品线什么都有,有新闻.门户.搜索.邮箱,当时在全球范围么还是比较领先的.它的变现的形态和广告

中国软件技术大会2016 深度探讨软件技术热点

2016中国软件技术大会将以"互联网+"时代企业级应用新生态为主题,大会将邀请五十多位著名互联网公司的技术大咖.行业企业的技术专家.技术畅销书的作者.独立咨询师等就多个新兴前沿领域,从独立于厂商的角度,深入解析最新技术热点,探讨当前的技术变革对企业级软件的开发技术.架构.运维的影响力和驱动力. 会议时间:2016年12月9-10日 会议地点:北京国家会议中心 主办单位:中科院软件研究所 中科软科技股份有限公司 计算机世界 大会主题:"互联网+" 时代企业级应用新生态

深度剖析核心交换机性能参数

一条单一的链路被设计去处理广播包或不知目的地的包,给端口提供一个几倍于独立端口的独享的高带宽,看完本文你 肯定有不少收获,希望本文能教会你更多东西.在核心交换机中使用TRUNK功能到底能给我们带来哪些应用方面的优势?还有在具体的核心交换机产品中怎样来配置TRUNK,下面文章就对人们关心的核心交换机中的TRUNK配置功能进行说明研究.核心交换机的TRUNK配置功能非常重要,同时对TRUNK进行合理的配置,可以为互连的交换机之间提供更好的传输性能.到底什么是TRUNK呢?使用TRUNK功能到底能给我