您现在的位置:计算机技术学习网 > 技术中心 > WEB编程 > PHP >

浅谈PHP缓存技术之三

来源:网络 责任编辑:栏目编辑 发表时间:2013-07-01 18:07 点击:

php应用程序的性能优化

使用PHP编程的最大好处是学习这种编程语言非常容易以及其丰富的 库。即使对需要使用的函数不是十分了解,我们也能够猜测出如何完成一个特定的任务。

尽管PHP非常简单易学,但我们仍然需要花费一点时 间来学习PHP的一些编程技巧,尤其是与性能和内存占用相关的技巧。在PHP中,有许多小技巧能够使我们减少内存的占用,并提高应用程序的性能。在本篇文 章中,我们将对PHP应用程序的分析、如何改变脚本代码以及比较优化前后的各种参数值进行简要的介绍。

通过在程序中设置计时的程序,并反复执行这些代码,我们可以获得有关程序执行速度的一组数据,这些数据可以可以用来发现程序中的瓶颈,以及如何进行 优化,提高应用程序的性能。

也许读者曾经听说过PEAR库吧。我们将使用PEAR库创建在分析时需要使用的例子,这也是对现有的代码进行分析的最简单的方法,它使我们无需使用 商用产品就能对代码进行分析。

我们要使用的库的名字是PEAR::Benchmark,它对于对代码进行分析和性能测试非常有用。这个 库提供一个名字为Benchmark_Timer()的类,能够记录一个函数调用和下一个函数调用之间的时间。在对代码的性能进行测试时,我们可以得到一 个详细的脚本执行结果,它非常简单,如下所示:

include_once("Benchmark/Timer.php");

$bench = new Benchmark_Timer;

$bench-> start();

$bench-> setMarker(Start of the script);

// 现在处于睡眠状态几分钟

sleep(5);

$bench-> stop();

// 从计时器中获得分析信息

PRint_r($bench-> getProfiling());

?> 

上面代码执行后的输出如下所示:

Array

(

[0] =>    Array

(

[name] =>    Start

[time] =>    1013214253.05751200

[diff] =>    -

[total] =>    0

)

[1] =>    Array

(

[name] =>    Start of the script

[time] =>    1013214253.05761100

[diff] =>    9.8943710327148E-05

[total] =>    9.8943710327148E-05

)

[2] =>    Array

(

[name] =>    Stop

[time] =>    1013214258.04920700

[diff] =>    4.9915959835052

[total] =>    4.9916949272156

)

)

上 面的数字似乎是一组杂乱无章的数字,但如果程序的规模更大,这些数字就十分地有用了。

也许广大读者也能猜测到,数组的第一个表目是实际 调用Benchmark_Timer()类的方法,例如

$bench-> start()、$bench-> setMarker()和$bench-> stop(),与这些表目有关的数字是相当简单的,现在我们来仔细地研究这些数字:

[0] =>    Array

(

[name] =>    Start

[time] =>    1013214253.05751200

[diff] =>    -

[total] =>    0

)

time 表目指的是何时对Benchmark_Timer()的start()方法调用的UNIX的timestamp,diff表目表示这次调用和上次调用之间 的时间间隔,由于这里没有上一次,因此显示出了一个破折号,total表目指的是自测试开始到这一特定的调用之前代码运行的总的时间。下面我们来看看下一 个数组的输出:

[1] =>    Array

(

[name] =>    Start of the script

[time] =>    1013214253.05761100

[diff] =>    9.8943710327148E-05

[total] =>    9.8943710327148E-05

)

从上面的数字我们可以看出,在调用$bench-> start()之后,程序运行了9.8943710327148E-05秒(也就是0.0000989秒)后开始调用$bench-> setMarker(….)。

一次真实的性能测试经历

尽管上面的例子不错,但在对于决定如何优化你的站点代码设计方面,它 真的不能算是一个好例子。下面我将用我自己作为网站技术人员的一段亲身经历来说明如何解决性能方面存在的问题。

我并不大理解网站使用的 代码,因为它是根据特殊的需求,历经多年开发而成的━━其中的一个模块包括网站转换代码,另一个模块记录网站的使用情况,其他的模块也各有各的作用。我和 网站的主要开发者都意识到网站的代码需要优化,但又不清楚问题出在哪儿。

为了尽快地完成任务,我开始研究网站的主要脚本代码,并在全部 脚本代码以及其包含文件中添加了一

    发表评论
    请自觉遵守互联网相关的政策法规,严禁发布色情、暴力、反动的言论。
    用户名: 验证码:点击我更换图片
    最新评论 更多>>

    推荐热点

    • PHP测试
    • 十天学会php之第六天
    • 几种显示数据的方法的比较
    • 使用xmlhttp为网站增加域名查询功能
    • PHP+MYSQL+Javascript数据库查询结果的动态显示
    • 查找数组中指定键名的值
    • 用redis实现跨服务器session
    • 用新浪微博接口发送图片微博失败的原因
    • smarty局部缓存技术[源码分析]
    网站首页 - 友情链接 - 网站地图 - TAG标签 - RSS订阅 - 内容搜索
    Copyright © 2008-2015 计算机技术学习交流网. 版权所有

    豫ICP备11007008号-1