PHP应用程序的性能优化

程序|性能|优化

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

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

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

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

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

<?php
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(....)。

一次真实的性能测试经历

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

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

为了尽快地完成任务,我开始研究网站的主要脚本代码,并在全部脚本代码以及其包含文件中添加了一些$bench->setMarker()命令,然后分析$bench->getProfiling()的输出,并对得到的结果大吃一惊,原来问题出在一个与获得特定语言名字(例如en代表english)的转换代码的函数调用中,该函数在每个页面上都会被使用数百次。每次调用该函数时,脚本代码都会对一个MySQL数据库进行查询,从一个数据库表中获得真正的语言名字。

于是我们这一类的信息创建了一个缓冲系统。经过短短2天时间的工作,我们使系统的性能得到了很大的提高,第一周内页面的浏览量也因此而增加了40%。当然了,这只是一个有关分析代码能够提高互联网应用或互联网网站性能的例子。

性能测试函数调用

在分析一个脚本或网页(以及其包含文件)时,尽管Benchmark_Timer()特别有用,但它并不科学,因为要获得分析的数据我们必须多次加载脚本,而且它也不是针对某个类或函数调用的。

PEAR::Benchmark库中的另一个被称作Benchmark_Iterator的类能够很好地解决这一个问题,它能够针对特定的函数或类的方法,显示其分析信息。它的用途是能够能够从测试中获得一致的结果,因为我们知道,如果运行一段脚本一次,其运行时间为10秒,并不意味着它每次的运行时间总是10秒。

In any case, let's see some examples:

// 连接数据库的代码
  include_once("DB.php");
  $dsn = array(
  'phptype' => 'mysql',
  'hostspec' => 'localhost',
  'database' => 'database_name',
  'username' => 'user_name',
  'password' => 'password'
  );
  $dbh = DB::connect($dsn); function getCreatedDate($id)
  {
  global $dbh; >$stmt = "SELECT created_date FROM users WHERE id=$id";
  // 在这里使用PEAR::DB
  $created_date = $dbh->getOne($stmt);
  if ((PEAR::isError($created_date)) ||
  (empty($created_date))) {
  return false;
  } else {
  return $created_date;
  }
  }include_once 'Benchmark/Iterate.php';
  $bench = new Benchmark_Iterate; // 运行getDate函数10次
  $bench->run(10, 'getCreatedDate', 1);// 打印分析信息
  print_r($bench->get());
  ?>

运行上面的代码能够产生与下面相似的结果:

Array
  (
  [1] => 0.055413007736206
  [2] => 0.0012860298156738
  [3] => 0.0010279417037964
  [4] => 0.00093603134155273
  [5] => 0.00094103813171387
  [6] => 0.00092899799346924
  [7] => 0.0010659694671631
  [8] => 0.00096404552459717
  [9] => 0.0010690689086914
  [10] => 0.00093603134155273
  [mean] => 0.0064568161964417
  [iterations] => 10
  )
上面的这些数字很好理解,mean条目表示getCreatedDate()函数10次运行的平均时间。在进行实际测试时,应该至少运行1000次,但这个例子得出的结果已经足够说明问题了。

结束语

希望广大读者能够通过本篇文章掌握如何迅速地对PHP代码进行分析的基本方法。在这里我还还要提醒广大读者的是,对代码进行分析不是一件简单的事儿,因为我们必须掌握大量的有关该种语言的特性。在代码中添加计时用的代码有助于找出运行速度缓慢的函数,利用多次重复的方法使我们能够发现对代码进行正确优化的方法。

时间: 2024-08-27 22:33:23

PHP应用程序的性能优化的相关文章

快”在细节 J2EE程序的性能优化技巧

j2ee|程序|技巧|性能|优化 应用J2EE平台开发的系统的性能是系统使用者和开发者都关注的问题,本文从服务器端编程时应注意的几个方面讨论代码对性能的影响,并总结一些解决的建议. 关键词:性能,Java,J2EE,EJB,Servlet,JDBC 一.概要 Java 2 Platform, Enterprise Edition (J2EE)是当前很多商业应用系统使用的开发平台,该技术提供了一个基于组件的方法来设计.开发.装配和部署企业级应用程序.J2EE平台提供了一个多层结构的分布式的应用程序

【中亦安图】清算/报表/日终跑批程序之性能优化案例(5)

第一章 技术人生系列 · 我和数据中心的故事(第五期)-清算/报表/日终跑批程序之性能优化案例(一) 中亦安图 | 2016-02-18 21:40 前言 不知不觉,技术人生系列·我和数据中心的故事来到了第五期.小y又和大家见面了! 前几期主要发了一些TroubleShooting的案例分享,其实小y最擅长的是性能优化,所以从这期开始,小y会陆续的分享更多的数据库性能优化案例. 进入正题,如果您的日终跑批/清算/报表等程序时快时慢,或者从某一天以后就一直变慢,作为运维DBA或开发的您,会怎么下手

ASP程序的性能优化

程序|性能|优化 第一章 使用服务器缓存 1.使用application和session保存数据的技巧. 可以再程序启动或会话开始时将需要的数据赋值给application和session对象.使用这种方法只需要在global.asa文件的application_Onstart和session_OnStart函数中添加响应的赋值函数或语句即可. 再合适的条件下可以缓存ADO记录本身,但是需要注意: 1.ADO记录必须时自由线程标记的 2.必须时已经断开的记录集 3..在服务器硬盘上缓存数据 对于

JAVA程序的性能优化

程序|性能|优化   1 使用非阻塞I/O 版本较低的JDK不支持非阻塞I/O API.为避免I/O阻塞,一些应用采用了创建大量线程的办法(在较好的情况下,会使用一个缓冲池).这种技术可以在许多必须支持并发I/O流的应用中见到,如Web服务器.报价和拍卖应用等.然而,创建Java线程需要相当可观的开销. JDK 1.4引入了非阻塞的I/O库(java.nio).如果应用要求使用版本较早的JDK,在这里有一个支持非阻塞I/O的软件包. 2 慎用异常 异常对性能不利.抛出异常首先要创建一个新的对象.

Java程序的性能优化StringBuffer与Vector

程序|性能|优化 ? Java使得复杂应用的开发变得相对简单.毫无疑问,它的这种易用性对Java的大范围流行功不可没.然而,这种易用性实际上是一把双刃剑.一个设计良好的Java程序,性能表现往往不如一个同样设计良好的C++程序.在Java程序中,性能问题的大部分原因并不在于Java语言,而是在于程序本身.养成好的代码编写习惯非常重要,比如正确地.巧妙地运用java.lang.String类和java.util.Vector类,它能够显著地提高程序的性能.下面我们就来具体地分析一下这方面的问题.

Flex应用程序的性能优化

众所周知,flex应用程序存或多或少地存在性能方面的问题.特别是企业级大数量的应用程序,通常的解决办法是分模块加载,分时加载数据等措施来解决.下面我们来谈一谈代码级别的优化: 1.尽可能减少程序的不必要运算.如下两种表达式: var a:unit = b+(1024-200)/2;    var a:unit = b+412;  很明显下面的那个表达式运算更快. 2.尽可能地采用乘法运算来代替除法运算.如下两个表达式: result = num / 4;    reuslt = num * 0.

技巧:最大限度优化你的Asp程序的性能

程序|技巧|性能|优化 ASP 能快速执行你的动态网页,但你还可以通过紧缩代码和数据库连接以使它们执行更快.这是一篇关于怎样精简代码和Asp 特征以获得最快执行速度的详细文章.对于一个急燥的用户来说,任何在按下用户按钮到结果出现在它们的屏幕之间的延迟可能意味着它们会转到浏览其它的站点?假如你的是商业站点,这有可能意味着失去潜在的销售. 我们没有任何办法控制用户的带宽,但我们的确能通过优化Asp 站点来获得最佳的性能.大部分潜在性能的提升是通过系统改变而不是紧缩代码,一个不合适的想法是,一旦遇到系

Android性能优化典范 - 第2季

Google前几天刚发布了Android性能优化典范第2季的课程,一共20个短视频,包括的内容大致有:电量优化,网络优化,Wear上如何做优化,使用对象池来提高效率,LRU Cache,Bitmap的缩放,缓存,重用,PNG压缩,自定义View的性能,提升设置alpha之后View的渲染性能,以及Lint,StictMode等等工具的使用技巧. 下面是对这些课程的总结摘要,认知有限,理解偏差的地方请多多指教! 1)Battery Drain and Networking 对于手机程序,网络操作相

面向程序员的数据库访问性能优化法则

面向程序员的数据库访问性能优化法则     http://blog.csdn.net/yzsind/archive/2010/12/06/6059209.aspx