PHP性能优化简述

时间:2022-12-13 11:09:57
先谢慕课网,这里只做理论简述
/**
* PHP性能优化
*
* 1.问题分析
* PHP语法使用不正确
* PHP不擅长的事
* PHP连接的服务不给力
* PHP自身短板
* 其它原因
* 2.PHP项目性能问题占整个项目的性能问题
* PHP性能问题不会超过整个项目性能问题的一般,通常占30%到40%,
* 优化整个项目不仅优化PHP性能,整个项目中PHP性能问题只占一部分。
* 优化过程:
* 1.php语言级的性能优化;快速见到收益
* 2.php周边问题的性能优化;web server,mysql等等
* 3.php自身分析优化;
*
* 压力测试软件
* Linux下安装apache会自带ab压力测试工具
* ./ab -n1000 -c100 http://www.baidu.com
* -n总请求 -c并发
* 注意如果有白名单需要先把本地ip加入白名单,否则会被认为ddos攻击;
* 主要查看 Request per second 每秒接受的请求数,越多越好
* Time per request 每个请求耗时,越小越好
*
*/ /*
*
* PHP语言级的优化
* 1.少写代码,多用PHP自身的能力;
* 比如说使用PHP内置函数/变量/常量来使实现功能;
* 2.PHP内置函数的性能优劣,PHP内置函数,可能实现相同功能,但也存在差异;
* 比如说isset($arr[$i])/array_key_exists($i,$arr);
* 3.尽量少用魔法函数,PHP提供的魔法函数,性能不佳;
* 比如说__get(),time php test.php;
* 4.产生额外开销的错误抑制符;
* 错误抑制符,就是在代码前后添加Opcode,Opcode的作用就是忽略报错。尽量不要使用。try throw好一些;
* 5.合理使用内存;
* 利用unset及时释放不使用的内存;
* 6.尽量少使用正则表达式;
* 利用字符串处理函数好一些;
* 7.避免在循环里面做运算;
* 将计算放在循环之外,循环上做两个变量的比较;
* 8.减少计算密集型业务;
* 大批量的数据处理,大批量的日志分析,PHP的语言使用C写的,PHP运算的开销比C大;
* PHP使用衔接Web server和后端服务,UI呈现,字符串文本处理;
* 9.务必使用带引号字符串做数组的键值;
*
*
*
* vld工具可以查看opcode,是一个PHP扩展;
*
* PHP代码运行流程:php代码通过zend引擎逐行扫描,解释称zend引擎自己能识别的语法,
* 通过解析,解析成opcodes,opcodes拿来执行,完成output;
* PHP缓存都是缓存Opcodes。
*/ /**
* PHP周边问题的优化
* 1.Linux运行环境
* Linux服务器中运行PHP,所以环境很重要,Linux跑的快与慢很重要!
* 2.文件存储,硬盘的性能,硬盘的写入读取;
* 3.Mysql数据库,基于文件系统;
* 磁盘是硬件,数据库是软件;
* 数据库的性能也决定着PHP的快慢;
* 4.缓存,内存,硬件的内存,软件的memcache,redis等;
* 5.网络
*
* 连接外部数据库耗时需要 网络+数据库,PHP文件的耗时,也有周边服务的耗时!
* 如果是数据库的问题,优化语法就没有用!
*
* 建议:
* 1.减少文件类操作;读写磁盘/读写数据库/读写内存/读写网络数据;
* 读写内存<读写数据库<读写磁盘<读写网络数据;
* 常用的数据库会用内存作为缓存!先将只能写入内存,写入成功之后才操作,比直接操作磁盘快一些!
* 网络数据通过socket,也是一个磁盘操作!有网络延迟!无法确认机房网络是优良的!尽量减少读写网络的情况!
* 数据库,磁盘,网络都是基于文件系统,基于硬盘!
* 内存操作基于内存,直接与内存交互,开销很小速度更快!
* 尽量多的操作内存数据库,少操作磁盘网络数据!
*
* PHP请求网络接口的优化:
* 对方接口的不确定因素/网络不稳定性
* 1.设置超时时间:连接超时/读超时/写超时,建议连接超时200毫秒,读超时800毫秒,不可大于1秒,写超时500毫秒!
* 2.将串行请求并行化:curl改成curl_multi_*()/使用swoole扩展
*
* PHP做接口,压缩PHP接口输出!
* 使用Gzip即可!client端更快的获取数据,但是会产生额外的CPU开销;数据小于100k的时候,压缩没有太大效果!
*
* 缓存重复计算内容:
* 多次请求,内容不变情况,使用缓存;常用在模版输出上,smarty用cache功能;
*
* 重叠时间窗口思想:后面的任务不强依赖前一个任务;定时缓存!
* 旁路方案:模版渲染环节!
*
*
*/ /**
* PHP性能的具体分析
* XHPorf工具;
* php --ri xhporf 查看是否支持xhporf
*/
/**
* PHP性能瓶颈解决方法:
* Opcode cache:PHP扩展APC;对Opcode做缓存!php的pecl站点,看PHP扩展!
* 通过PHP扩展代替啊源代码中高频逻辑
* Runtime优化:HHVM
*/ /**
* PHP主要就是在读写内存,读写数据库,读写磁盘,读写网络数据;
* PHP项目的优化也就是缓存的优化/网络的优化/数据库的优化,以及PHP部署在Linux环境上,Linux对PHP的性能也有影响!
* mysql的优化很重要,其他的优化也不能忽视!
* 读写内存比数据库快,数据库比磁盘快,磁盘比网络数据快,因为网络数据也是基于文件系统,并且跟网络的稳定性相关;
* 通常尽量避免获取网络数据,当必须使用网络接口提供的数据时,应该设置连接超时,读超时,写超时等!
* 然后就是多操作缓存,较少磁盘操作,可以使用memcache,redis缓存较少读写磁盘的开销!
* 数据库虽然也是基于文件系统的,但是他又比直接操作磁盘快,因为大部分数据库都是用内存做缓存,写入缓存成功就会返回结果,所以比直接操作磁盘要快!
* 总之就是多操作内存数据库,少操作磁盘,网络数据!
* 另外Linux系统,Web server的性能也影响PHP的性能!
* 然后,再来说一下数据库的优化,常用的就是MySQL数据库,所以就是Mysql的优化!
*
*/

PHP性能优化简述的更多相关文章

  1. 2020重新出发,MySql基础,性能优化

    @ 目录 MySQL性能优化 MySQL性能优化简述 使用 SHOW STATUS 命令 使用慢查询日志 MySQL 查询分析器 EXPLAIN DESCRIBE 索引对查询速度的影响 MySQL优化 ...

  2. 手游录屏直播技术详解 &vert; 直播 SDK 性能优化实践

    在上期<直播推流端弱网优化策略 >中,我们介绍了直播推流端是如何优化的.本期,将介绍手游直播中录屏的实现方式. 直播经过一年左右的快速发展,衍生出越来越丰富的业务形式,也覆盖越来越广的应用 ...

  3. SQL Server数据库性能优化之索引篇【转】

    http://www.blogjava.net/allen-zhe/archive/2010/07/23/326966.html 性能优化之索引篇 近期项目需要, 做了一段时间的SQL Server性 ...

  4. Android性能优化的浅谈

    一.概要: 本文主要以Android的渲染机制.UI优化.多线程的处理.缓存处理.电量优化以及代码规范等几方面来简述Android的性能优化 二.渲染机制的优化: 大多数用户感知到的卡顿等性能问题的最 ...

  5. Web前端性能优化的9大问题

    1.请减少HTTP请求基本原理:在浏览器(客户端)和服务器发生通信时,就已经消耗了大量的时间,尤其是在网络情况比较糟糕的时候,这个问题尤其的突出.一个正常HTTP请求的流程简述:如在浏览器中输入&qu ...

  6. Spark实践 -- 性能优化基础

    性能调优相关的原理讲解.经验总结: 掌握一整套Spark企业级性能调优解决方案:而不只是简单的一些性能调优技巧. 针对写好的spark作业,实施一整套数据倾斜解决方案:实际经验中积累的数据倾斜现象的表 ...

  7. &lbrack;Android&rsqb;Android性能优化

    安卓性能优化 性能优化的几大考虑 Mobile Context 资源受限 + 内存,普遍较小,512MB很常见,开发者的机器一般比用户的机器高端 + CPU,核心少,运算能力没有全开 + GPU,上传 ...

  8. web前端性能优化的技巧

    1. 请减少HTTP请求 基本原理: 在浏览器(客户端)和服务器发生通信时,就已经消耗了大量的时间,尤其是在网络情况比较糟糕的时候,这个问题尤其的突出. 一个正常HTTP请求的流程简述:如在浏览器中输 ...

  9. 01&period;SQLServer性能优化之----强大的文件组----分盘存储

    汇总篇:http://www.cnblogs.com/dunitian/p/4822808.html#tsql 文章内容皆自己的理解,如有不足之处欢迎指正~谢谢 前天有学弟问逆天:“逆天,有没有一种方 ...

随机推荐

  1. mysql大小写敏感与校对规则

    大家在使用mysql过程中,可能会遇到类似一下的问题: root@chuck 07:42:00>select * from test where c1 like 'ab%';  +-----+  ...

  2. MSSQL sp&lowbar;helptextplus

    默认的sp_helptext 如果存储过程每行代码太长会自动截断 把这个sp_helptextplus添加到SSMS的keyboard快捷键里面 SET QUOTED_IDENTIFIER ON SE ...

  3. 前端笔试面试中的常用知识点总结&lpar;CSS&rpar;

    1.CSS选择器的优先级!important  > 内联 > id选择器 > 类选择器 > 标签选择器多个类选择器叠加(256)之后的优先级大于一个id选择器!importan ...

  4. mac git 的安装 及实现自动补全

    1.检查是否装了brew $ brew list如果没有,拷贝以下命令到终端 回车.可以安装好brewruby -e "$(curl -fsSL https://raw.githubuser ...

  5. Unix文件 I&sol;O&lpar;不带缓冲区的&rpar;上

    简介 Unix系统大多数文件i/o只需要:open.read.write.lseek.close这几个函数.但是某些时候我们也需要fcntl.ioctl.sync等函数配合使用.这些函数都是不带缓冲区 ...

  6. Oracle数据库中OVER&lpar;&rpar;函数的了解

    1.over函数介绍:      开窗函数,Oracle从8.1.6开始提供分析函数,分析函数用于计算基于组的某种聚合值,它和聚合函数的不同之处是:对于每个组返回多行,而聚合函数对于每个组只返回一行. ...

  7. vscode 添加 includePath

    使用vscode打开C项目时,vscode无法找到头文件路径,提示:configure includePath for better intellisense results 解决: 编辑~/.vsc ...

  8. Mysql在linux下载、安装详情,附带mysql安装包路径

    对mysql在linux的安装网上很多,但是都比较坑人,mysql的下载.到用什么包安装,安装过程没有具体解析 我最痛苦的其实是找安装包,建议找.tar.gz安装包比较好(下面我为同胞们找到了mysq ...

  9. learning docker steps&lpar;5&rpar; ----- docker stack 初次体验

    参考:https://docs.docker.com/get-started/part5/ stack 技术栈.技术栈是一组相关的服务,它们共享依赖项并且可以一起进行编排和扩展.单个技术栈能够定义和协 ...

  10. mysqldump&colon; Got errno 32 on write 解决办法

    在执行mysqldump 时发生 mysqldump: Got errno 32 on write 报错: $ sudo mysqldump -u root -p ******* | gzip &gt ...