php专区

 首页 > php专区 > PHP进阶 > 高并发 > PHP系统性能优化原则良好的系统设计

PHP系统性能优化原则良好的系统设计

分享到:
【字体:

这里记载的是我觉得在做优化工作时应该秉承的原则与步骤,不是具体的优化方法(优化方法google有很多)。

一提到性能优化,就会听到双引号、单引号、三等号之类的,我认为如果按着这个去做,就有点舍本逐末了。

做优化之前,先说一下我对系统设计目标的理解

  • 第一位:可运行。这是最重要的,应该没有什么异议。
  • 第二位:可维护。要保证一段时间以后,别人或你自己可以对这套设计进行维护。
  • 第三位:性能与其它

其中,第二位与第三位的顺序肯定有人提反对意见,因为我一个朋友就提过,但一段时间后,他也同意了可维护要比性能更重要些。 这里只能说是我个人的经验,没有办法像数学公式证明那样一步步的给出证明过程。

优化顺序

这里从PHP程序本身来说下性能。

首先:良好的系统设计

我敢保证,对于Web系统,绝大多数情况下PHP本身不会成为性能瓶颈。瓶颈经常是系统设计、业务逻辑梳理有问题。 如果系统设计不合理,就算我们把所有的双引号替成单引号也无济于事。

这里举个例子,我们一个系统设计初期没有很多对cache访问进行规划,单次请求中cache访问次数过多,出现 还不如访问数据库快的情况。(因此,cache应该像关系表那样从一开始便进行精心设计)

然后:代码与脚本

这一步也比较关键,实际中经常会碰到过两类问题:

  • 循环中套了sql操作。
  • 脚本过多、过大。

其中第二类问题大家经常忽略。前不久我们访问一个内部服务(依赖其提供的sdk),性能怎么都提不上去。最后 我把sdk中所有的类都合并到一个文件中,性能瞬时提高了10%。这是脚本过多的问题,我们解决了,但是脚本过大的 问题我们没有解决,因为就算合并后,代码也是有几千行,在xhprof呈现的性能report里仍然是一个大大的方框。

对于脚本过大,再提个大家可能不太容易注意到的建议:把controller/action设计改成action设计, 这样可以避免超大controller的出现,从而提升部分性能。

对于单引号、双引号问题,我建议在项目中保持统一即可。要么单双分开用,要么统一双引号,这不会 成为性能的瓶颈所在。

对于三等号、双等号问题,我建议主要从程序逻辑正确性这方面来考虑如何使用。

说到脚本了,提个长久一来的疑问:smarty等有必要存在么?php的原生模板语法不是更好么?

最后:着眼PHP本身

如果系统性能还是不理想,则需要从服务器环境本身来考虑考虑了。

  • 如果php version
  • 部分稳定、公用的逻辑,写成PHP扩展。比如程序框架(@see yaf)、访问纯真ip数据库等。

做了这么多年web,我一直相信一点——PHP本身很难成为性能瓶颈所在。

分享到:
说说PHP中file_put_contents并发性问题解...
在使用file_put_contents时会碰到并发性问题了,对于这个问题我们有多种解决方案了,其实锁是小编比较喜欢的解决办法了,当然也有其它办法,具体如下。 解决 办法一,file_put_contents 高并发与独占锁定   发现高并发访问时使用 file_put_contents 写入文件造成数据置空。 查看官方文档: ...
PHP大量数据循环时内存耗尽问题的解决方...
最近在开发一个PHP程序时遇到了下面的错误: PHP Fatal error: Allowed memory size of 268 435 456 bytes exhausted 错误信息显示允许的最大内存已经耗尽。遇到这样的错误起初让我很诧异,但转眼一想,也不奇怪,因为我正在开发的这个程序是要用一个foreach循环语句在一个有4万条记录的表里全表搜索具有特定特征的...
  •         php迷,一个php技术的分享社区,专属您自己的技术摘抄本、收藏夹。
  • 在这里……