PHP性能优化

规范说明

性能是网站运行是否良好的关键因素, 网站的性能与效率影响着公司的运营成本及长远发展,编写出高质高效的代码是我们每个开发人员必备的素质,也是我们良好的职业素养。

影响性能的因素

  • 商业需求
    • 需求合理性
    • 需求与系统的整合
    • 需求所带来的商业利益是否与需求开发的成本成正比
    • 需求所带来的风险
  • Web 服务器
    • 并发处理能力
    • 高负载的能力
    • 负载均衡的能力
    • 动态内容与静态内容的处理能力
    • Web 服务器部署
  • DataBase 服务器
    • 并发访问
    • 数据库服务器的部署
    • 数据库的 shema 架构与的表设计是否合理
    • 数据检索
  • 操作系统
  • 客户端请求
  • 程序/语言

分析性能的指标

  • 程序的运行时间
  • 程序的运行所消耗的内存
  • 单位时间内的并行处理
  • 磁盘 IO 的处理

优化性能的目标

快速、并发、资源消耗低(内存、磁盘 IO、CPU 负载)

优化性能的原则

  • 服务器配配置最优化
  • 服务器部署合理化
  • 商业需求合理并与产出的商业价值成正比
  • 架构可用、可维护、可扩展
  • 程序的正确性、简单性、逻辑的合理性。
  • 不断的分析性能的的瓶颈
  • 不断的重构已有的代码
  • 优化的优先级:program->database->web sersver->os->client

优化

程序优化

  • 变量
    • 变量大小,注意变量大小是节约内存的最有效手段,对于来自用户表单、数据库和文件缓存的数据都需要控制变量的大小。 因为cpu要处理的数据是来源于内存
    • 变量有效期,使用unset()函数注销不需要的变量是一种良好的习惯,将一些不需要的变量立即注销可提高内存的使用率。
    • 复制变量,尽量不要复制变量,否则就会带来1倍的内存消耗,即使复制变量也应该要立即注销原有变量。
    • 变量类型,初始化变量请注意其变量类型,一个变量在执行过程中最好只有一种类型状态。对于数组变量,请初始化声明,如下: $a = array();
    • 临时变量,是处理业务逻辑的临时存储,这些都是需要消耗内存的。如果临时变量使用结束请立即注销,特别是在一些过程式代码的执行流程中,对于一些函数,如果业务非常复杂,同样需要立即注销临时变量
    • 静态变量,对于一些需要由复杂业务产生的变量,如果在程序的执行过程中多次产生并使用,可考虑使用静态变量,减少程序的cpu执行次数
    • 变量的性能:局部变量>全局变量>类属性>未定义的变量。
  • 循环
    • 尽量减少循环的次数。
    • 尽量减少循环的潜逃的层次,不要超过三层。
    • 避免在循环内有过多的业务逻辑。
    • 不要循环包含文件
    • 不要循环执行数据库操作。
    • 优先使用foreach,它比for/while效率高,如果循环内要调用函数,用array_walk最好,它的效率要比for 高出1倍,要比foreach高出43%的效率
    • 不要把 count/strlen/sizeof 放到 for 循环的条件语句中 For($i=0,$count=count($array);$i<$count;$i++){} 不要使用for($i=0;$i<count($array);$i++){};
    • for($i=$total;$i>0;$i–){}性能好于for($i=0;$i<$total;$–){}
    • 保持循环体内的业务逻辑清晰
  • 函数
    • 函数职责清晰,一个函数只干一件事,不要杂揉过多的业务逻辑
    • 函数代码体不要超过20行,反之,考虑拆分。
    • 优先使用php内置函数
    • 常量与函数同时能干一件事,优先使用常量。 phpversion() < PHP_VERSION get_class() < CLASS is_null() < NULL ===
    • echo 的性能好于print,输入多个变量的时候用echo $str,$str1,不用.连接符
    • $_SERVER[REQUEST_TIME]替换time();
    • 字符串替换strtr()->str_replace()->preg_replace()->epreg();
    • 发挥trim最大功效,替换substr。$filepath=trim($filename,’/’).’/’;
    • Isset/empty 虽然两个函数功能有所差异,但在同样的情况下推荐使用 empty()
    • isfile/file_exist 两个函数的功能有所不同,file_exist既可判断文件是否存在,也可以判断目录是否存在,在同样的情况下推荐使用is_file
  • 文件
    • 减少文件包含数,减少磁盘 IO
    • 使用完整路径,或者容易转换的相对路径。避免在 include_path 查找
    • 文件的代码行数不要超过 2000 行
    • Require_once/include_once 效率低于 require/include, 需要额外的去查看系统是否已经调用过这个文件. 因为它们在一个 opcode 缓存下的调用非常慢
    • 程序执行文件用 requie/require_once,缓存文件用include/include_once。Include 效率好于 require
    • 优化 spl 中的文件自动加载机制,可参靠 yii
    • 类库文件加载,是否考虑类是否已经实例化,可考虑采用设计模式之单例模式
    • 文件读写的并发性
  • 面向对象
    • 控制实例的创建的数量
    • 优先使用常量、类常量
    • 优先例用静态变量,静态属性
    • 类的结构合理
    • 面象接口编程
    • 封装变化点
    • 依赖于抽象,不依赖于细节
    • 优先使用静态成员
    • 类的接口清晰稳定,类的职责单一,类与类的通信合理
    • 使用常量的好处 编译时解析,没有额外开销 杂凑表更小,所以内部查找更快 类常量仅存在于特定「命名空间」,所以杂凑名更短 代码更干净,使除错更方便
  • 字符串 用单引号替代双引号引用字符串;避免检索字符串中的变量
  • 运算
    • 用 i+=1 代替i=i+1。符合c/c++的习惯,效率还高
    • ++$i 的效率高于++$i,–$i 同理
  • 数组
    • 多维数组尽量不要循环嵌套赋值;
    • 使用$array[‘name’]方式访问数组,禁止$array[name]/$array[“name”]
  • 判断
    • 逻辑判断请优先使用switch 的方式,对于业务逻辑相对较多的情况请选择if/else,提高代码的可读性
    • 尽量控制if/else判断的个数,如果太多请考虑功能优化或代码优化
    • 尽量使用恒等用于比较判断,恒等的效率高于等于,而且还能避免一些类型强制转换的错误
    • if/else与_&&,单条语句判断请选择&&的形式, &&的效率高于if/else,如下 : if ($a == 1) { $b = 2; } 可选择为($a == 1) && $b = 2;

缓存

  • 使用php加速器,缓冲opcode
  • 例用memcache/nosql
  • 使用内存数据库、
  • 使用文件缓存
  • 缓冲功能

其它

  • 少用@符号,严重影响性能
  • 适时关闭远程资源连接如数据库,ftp、socket等,适时的清理这些资源
  • 合理的商业需情
  • 数据库 schema 架构优化
  • 垂直与水平分库分表
  • 索引优化,查询优化
  • 第三方开源检索工具(sphinx)
  • 主从数据库服务器的使用。
  • Web 服器优化(暂未整理,有相应的 Web 服务器优化手册)
  • 操作系统优化(暂未整理,有相应的 OS 优化手册)
  • 前端优化
    • 合理的 html 结构
    • 合理 html 与css 的同时,考虑 Css 设计合理,减少 http 请求
    • 合理 html 与java script 的同时,考虑拆分是否合理,减少 http 请求
    • 优化 java script 代码,让用户有良好的体验
    • 根据 http 协议,优化高并发请求

性能检测工具

  • Web Server
  • ab
  • http_load
  • xhprof
  • OneAPM
  • apd
  • xdebug
  • Mysql
  • explain
  • profiler

Table of Contents

@bingbo blog https://github.com/bingbo/blog

原文发布于微信公众号 - PHP技术大全(phpgod)

原文发表时间:2018-08-24

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

扫码关注云+社区

领取腾讯云代金券