1, 多用php提供的内置函数


php解释成 opcode来执行,内置函数使代码更少


2,不同的内置函数的机制不一样,性能也不一样, 比如 isset array_has_key

如何来测试,php脚本执行的时间呢?用 time 命令, time php 11.php


3,php的执行过程

*.php ->通过zend引擎scanner后,保存为zend引擎可以识别的语法exprs

然后解析(parser)成opcodes, 然后执行,最后输出


扫描 转码 解析 执行 


直接用内置函数,在扫描的阶段,就省了很多, 在zend引擎识别语法,,的时候,内置的也是比自己写的快, 最后生成的


opcodes 也是比自己实现的opcodes要少。


4,少用魔术方法,能不用就不用


5,php -dvld.active=1 -dvld.execute=0 11.php

安装完php的 dvld扩展后,可以用这个命令,来查看,php解释后生成的opcode代码。


例如 @ 忽略错误,这个是在代码执行前,生成把错误提示忽略,代码执行后,把错误提示再打开,增加了多余的开销,所以尽


量少用。


6,合理使用内存,建议大的数组用unset()及时释放不适用的内存(注:unset()出现注销不掉的情况)。


7,减少计算密集型业务


8,数组的key必须用引号括起来,否则或先去查找defind的变量



9,常见php场景的开销次序

读写内存  读写数据库 读写磁盘 读写网络数据

尽量避免从磁盘写入 读写一个文件,或者网络不稳定的数据。 尽量多的用读写数据库 读写内存


10,减少php发起的网络请求

(1),对方接口的不确定因素

(2),网络稳定性

优化方法:

(1),设置超时事件

a),链接超时,不超过200毫秒

b),读超时,800毫秒

c),写超时,500ms

(2),将串行请求并行化

a),使用curl_multi_*(),虽然并行了,但是多个并行请求的中间有一个慢了,那就需要等带最慢的请求完


b),使用swoole扩展(开源的并行网络请求框架)



11,压缩php输出的利与弊

用Gzip即可

利:利用我们的数据输出,client端能更快的获取数据

弊:额外的服务端cpu , client的cpu的开销


12,php缓存复用

多次请求,内容不变的情况


13,smarty 调优和重叠时间窗口思想

开启smarty开启caching


14,串行方案最慢, 重叠时间窗口思想  旁路方案

类似,初中课文中说的,统筹方法。


15,XHPorf 工具,facebook的php性能分析工具