经常有人说php速度慢,其实语言层面的速度差异和实际的业务相比,不在一个数量级。

业务的瓶颈往往在于io,而不是CPU。

0x0 语言

语法

  1. 单引号和双引号 单引号不解析字符串里的变量,而双引号会解析,如果需要大量处理字符串,建议用单引号和字符串连接符"."
  2. === 和 == ""会进行类型转换,比如"1"和1 ,用""为真,而"="为假,如果类型相同的话,使用""。
  3. 合理使用静态变量,如保存函数中只需要初始化一次的数据
  4. 局部变量优于全局变量
  5. 输出缓存控制 ob_xxx系列函数
  6. php7 针对项目单独优化 可参看鸟哥的文章
  7. 使用php7 增加变量的参数类型,减少类型转换
  8. 合理使用多线程和协程
  9. 更多语法上的优化可以看这篇文章

php.ini配置

网上有很多,可以参加这篇文章

第三方服务

利用第三方服务,可以把php不擅长的委托出去

  • gearman 分布式任务队列,教程
  • beanstalk 消息队列,教程
  • redis 缓存

    消息队列和任务队列,常用在比较耗时的任务,比如批量导出订单数据为excel时,web服务直接可以把这个消息

    放到消息队列里,在后台跑一个脚本,取出消息后,查询数据库导出订单。至于后台使用什么语言,则无所谓了。

    这两个队列有些相似之处,基本上使用消息队列就足够了。任务队列在编码上要稍微复杂点,要按照任务协议,实现worker。

    消息队列只需要subscribe这个队列,有消息来了,取出消息,然后处理就行。

框架

可以选择简洁的框架,减少框架内部的消耗,如slim,phalocn,yaf

字节码缓存

opcache、apc等

扩展

使用扩展,如把cpu密集型的改用C/C++开发扩展,可以使用PHP-CPP,或者PHP-X

辅助开发。

0x1环境

  • Nginx 优化,参考这篇文章

  • Apache 优化, 参考这篇文章

  • Linux系统优化,参考这篇文章

  • 使用负载均衡,部署多台服务器

0x2 算法

  • 递归算法改为非递归
  • 先排序再查找
  • 用哈希代替数组,如判断某个字符串在数组里是否存在,可以把数组改造为哈希,这样只需要判断哈希里key是否存在即可
  • 使用php内置的array_xxx,系列函数,搭配回调函数,解决数组过滤、查询、去重等
  • 利用redis的集合,如判断两组数据中重复的数据,求两组数据中的差异

0x3 业务

通过跑测试来判断瓶颈所在,再分别优化

io密集型

增大内存

  • 文件io

    memcache 缓存文件、异步读取
  • 网络io
    • 压缩 之前做游戏时,内网测试单台机器可以支撑1000多人同时在线,然而正式环境才只能支撑200多人。

      测试同学反馈是网络带宽不够,于是在服务端和客户端都做了gzip压缩,数据量减少到1/6,解决了外网问题。
    • 尝试更紧凑的结构如,xml替换为json,json替换为msgpack等
  • 数据库io
    • 分库
    • 分表
    • 分区
    • 索引
    • 读写分离
    • 缓存
    • 代理 如360的Atlas,golang开发的kingshard
  • 使用缓存
    • 浏览器 在http头中添加etag和cache控制缓存时间
    • cdn
    • redis
    • 服务端渲染

cpu密集型

把相关代码用C/C++改写为扩展

安装监控软件

如oneapm,听云、博瑞等,或者开源的Tideways

PHP优化——从语言到业务的更多相关文章

  1. CockroachDB学习笔记——[译]如何优化Go语言中的垃圾回收

    原文链接:https://www.cockroachlabs.com/blog/how-to-optimize-garbage-collection-in-go/ 原作者:Jessica Edward ...

  2. 【数据库】优化SQL语言

    第1章数据模型设计 第1条:确保所有表都有主键 [1]当表缺少主键时,会出现各种问题,所有表都必须有一列(或多列)设置为主键. [2]主键应当具备的特征 唯一性,值非空,不可变,尽可能简单 [3]不要 ...

  3. 如何优化C语言代码(程序员必读)

    1.选择合适的算法和数据结构 应该熟悉算法语言,知道各种算法的优缺点,具体资料请参见相应的参考资料,有很多计算机书籍上都有介绍.将比较慢的顺序查找法用较快的二分查找或乱序查找法代替,插入排序或冒泡排序 ...

  4. 每秒100W请求,12306秒杀业务,架构如何优化?

    如<同样是高并发,QQ/微博/12306的架构难度一样吗?>一文所述,同样是高并发场景,三类业务的架构挑战不一样: QQ类业务,用户主要读写自己的数据,访问基本带有uid属性,数据访问锁冲 ...

  5. iOS app性能优化的那些事

     iPhone上面的应用一直都是以流畅的操作体验而著称,但是由于之前开发人员把注意力更多的放在开发功能上面,比较少去考虑性能的问题,可能这其中涉及到objective-c,c++跟lua,优化起来相对 ...

  6. app 性能优化的那些事

    来源:树下的老男孩 链接:http://www.jianshu.com/p/5cf9ac335aec iPhone上面的应用一直都是以流畅的操作体验而著称,但是由于之前开发人员把注意力更多的放在开发功 ...

  7. 简单说说PHP优化那些事

    我们在编写程序时,总是想要使自己的程序占用资源最小,运行速度更快,代码量更少.往往我们在追求这些的同时却失去了很多东西.下面我想讲讲我对PHP优化的理解.优化的目的是花最少的代价换来最快的运行速度与最 ...

  8. 细说PHP优化那些事

    我们在用PHP编程的时候,总是想要使自己的程序占用资源最小,运行速度更快,代码量更少.往往我们在追求这些的同时却失去了很多东西.下面我想讲讲我对PHP优化的理解.优化的目的是花最少的代价换来最快的运行 ...

  9. 第 8 章 MySQL 数据库 Query 的优化

      前言: 在之前“影响 MySQL 应用系统性能的相关因素”一章中我们就已经分析过了Query语句对数据库性能的影响非常大,所以本章将专门针对 MySQL 的 Query 语句的优化进行相应的分析. ...

随机推荐

  1. hdu 2647 Reward(拓扑排序+反图)

    题目链接:https://vjudge.net/contest/218427#problem/C 题目大意: 老板要给很多员工发奖金, 但是部分员工有个虚伪心态, 认为自己的奖金必须比某些人高才心理平 ...

  2. 在 Windows 10 中使用 OpenAI Spinning Up

    前段时间,openAI 发布了 Spinning Up ,本篇博客将介绍如何在 Windows 系统中使用 Spinning Up. 什么是 Spinning Up 先来说说 Spinning Up, ...

  3. 蛋疼的mocha库-promise异步测试

    mocha 测试库的使用 错误的处理异步测试 异步当出现断言错误的时候,他会抛出错误,但不会把这次测试当作失败,就是正确的顺利通过测试了,很无语. promise的reject会在then的第二个函数 ...

  4. Docker镜像优化

    前言 上篇博文说到使用Visual Studio Tools for Docker帮助我们生成Dockerfile,现在我们讨论下生成的Dockerfile的优劣. 一.以往Dockerfile构建模 ...

  5. CPU HQ 什么意思

    CPU HQ 什么意思 High performance graphics, quad core 高性能图形,四核 参见:https://www.intel.cn/content/www/cn/zh/ ...

  6. CSDN 博客 美化 个性化

    韩梦飞沙  韩亚飞  313134555@qq.com  yue31313  han_meng_fei_sha ========= ======== <a href=" http:// ...

  7. Altium Designer Summer 09换成中文步骤

    1.打开Altium Designer Summer 09软件,在左上角file文件中点击,再打开Preferences出现如下,然后关闭软件在打开就完成了

  8. awk 入门教程

    作者: 阮一峰 日期: 2018年11月 7日   awk是处理文本文件的一个应用程序,几乎所有 Linux 系统都自带这个程序. 它依次处理文件的每一行,并读取里面的每一个字段.对于日志.CSV 那 ...

  9. 跟着ZooKeeper学Java——CountDownLatch和Join的使用

    在阅读ZooKeeper的源码时,看到这么一个片段,在单机模式启动的时候,会调用下面的方法,根据zoo.cfg的配置启动单机版本的服务器: public void runFromConfig(Serv ...

  10. oracle索引原理(b-tree,bitmap,聚集,非聚集索引)

    B-TREE索引 一个B树索引只有一个根节点,它实际就是位于树的最顶端的分支节点. 可以用下图一来描述B树索引的结构.其中,B表示分支节点,而L表示叶子节点. 对于分支节点块(包括根节点块)来说,其所 ...