浅谈PHP缓存技术之三

浅谈PHP缓存技术之三

ID:43993230

大小:55.50 KB

页数:8页

时间:2019-10-17

浅谈PHP缓存技术之三_第1页
浅谈PHP缓存技术之三_第2页
浅谈PHP缓存技术之三_第3页
浅谈PHP缓存技术之三_第4页
浅谈PHP缓存技术之三_第5页
资源描述:

《浅谈PHP缓存技术之三》由会员上传分享,免费在线阅读,更多相关内容在工程资料-天天文库

1、浅谈PHP缓存技术之三php应用程序的性能优化使用PHP编程的最大好处是学习这种编程语言非常容易以及其丰富的库。即使对需要使用的函数不是十分了解,我们也能够猜测出如何完成一个特定的任务。尽管PHP非常简单易学,但我们仍然需要花费一点吋间来学习PHP的一些编程技巧,尤其是与性能和内存占用相关的技巧。在PHP中,有许多小技巧能够使我们减少内存的占用,并提高应用程序的性能。在本篇文章中,我们将对PHP应用程序的分析、如何改变脚本代码以及比较优化前后的各种参数值进行简要的介绍。通过在程序中设置计吋的程序,并反复执行这些代码,我

2、们可以获得有关程序执行速度的一组数据,这些数据可以可以用来发现程序中的瓶颈,以及如何进行优化,提高应用程序的性能。也许读者曾经听说过PEAR库吧。我们将使用PEAR库创建在分析时需要使用的例子,这也是对现有的代码进行分析的最简单的方法,它使我们无需使用商用产品就能对代码进行分析。我们耍使用的库的名字是PEAR::Benchmark,它对于对代码进行分析和性能测试非常有用。这个库捉供一个名字为Benchmark_Timer()的类,能够记录一个函数调用和下一个函数调用Z间的时间。在对代码的性能进行测试时,我们可以得到一个

3、详细的脚本执行结果,它非常简单,如下所示:include_once("Benchmark/Timer.php〃);$bench=newBenchmark_Timer;$bench・start();$bench・setMarker(zStartofthescript');//现在处于睡眠状态几分钟sleep(5);$bench・stop();//从计时器中获得分析信息PRint_r($bench-getProfilingO);■上面代码执行后的输出如下所示:Array([0]=Array([name]=Start[tim

4、e]二1013214253.05751200[diff]=・[total]=0)[1]=Array[name]=Startofthescript[time]=1013214253.05761100[diff]二9.8943710327148E-05[total]=9.8943710327148E-05)[2]=Array([name]=Stop[time]=1013214258.04920700[diff]=4.9915959835052[total]=4.9916949272156))上面的数字似乎是一组杂乱无章的数

5、字,但如果程序的规模更大,这些数字就十分地有用了。也许广大读者也能猜测到,数组的第一个表目是实际调用Benchmark_Timer()类的方法,例如$bench-start()>$bench-setMarker()^U$bench-stop(),与这些表目有关的数字是相当简单的,现在我们来仔细地研究这些数字:[0]=Array([name]=Start[time]=1013214253.05751200[diff]=[total]=0)time表目指的是何时对Benchmark_Timer()的start()方法调用的

6、UNIX的timestamp,diff表日表示这次调用和上次调用之间的时间间隔,由于这里没有上一次,因此显示出了一个破折号,total表目指的是自测试开始到这一特定的调用之前代码运行的总的时间。下面我们来看看下一个数组的输出:[1]=Array([name]=Startofthescript[time]=1013214253.05761100[diff]=9.8943710327148E-05[total]=9.8943710327148E-05)从上面的数字我们可以看出,在调用$bench-start()Z后,程序运

7、行T9.8943710327148E-05秒(也就是0.0000989秒)后开始调用$bench-setMarker(…・)。一次真实的性能测试经历尽管上面的例子不错,但在对于决定如何优化你的站点代码设计方面,它真的不能算是一个好例子。下面我将用我自己作为网站技术人员的一段亲身经历来说明如何解决性能方面存在的问题。我并不大理解网站使用的代码,因为它是根据特殊的需求,历经多年开发而成的一其中的一个模块包括网站转换代码,另一个模块记录网站的使用情况,其他的模块也各有各的作用。我和网站的主要开发者都意识到网站的代码需要优化,

8、但又不清楚问题岀在哪儿。为了尽快地完成任务,我开始研究网站的主要脚本代码,并在全部脚本代码以及其包含文件中添加了一些$bench-setMarker()命令,然后分析$bench-getProfiling()的输出,并对得到的结果大吃一,惊,原来问题出在一个与获得特定语言名字(例如en代表english)的转换代码的函数调用屮,该

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。