细说PHP优化那些事

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

进行大范围的优化,而不是死啃某些程序代码

我这里所说的优化,基本上都是从服务器,Apache,数据库这些方面来进行的优化,而并不是对你的PHP代码加以改进从而提高程序的运行速度,因为比起你将程序中的正则优化为字符串处理函数从而提升程序速度来说,在大范围内进行的优化所需要的代价要比这个小的多,而获得报酬却要丰厚的多。

在非代码处进行优化有以下好处:

1、 通常情况下能够大大提高效率

2、 不会危及到代码的完整性

3、 能够快速部署

缓存技术

下面来说说常用的缓存技术,通过这些缓存技术能够大大的提高效率

在说到缓存技术的时候不得不提到memcached ,memcached是高效、快速的分布式内存对象缓存系统,主要用于加速 WEB开发动态应用程序。

Memcached的原理

memcached 是以守护程序方式运行于一个或多个服务器中,等待接收客户端的连接操作,客户端可以由各种语言编写(例如PHP)。PHP 等客户端在与 memcached 服务建立连接之后,接下来的事情就是存取对象了,每个被存取的对象都有一个唯一的标识符 key,存取操作均通过这个 key 进行,保存到 memcached 中的对象实际上是放置内存中的,并不是保存在 cache 文件中的,这也是为什么 memcached 能够如此高效快速的原因。

说完memcached,下面来说说常用的缓存方法

1、 编译与OPCODE缓存

因为PHP是解释型的语言,所以每个PHP文件在运行的时候都需要编译后再执行,同一个文件,不同的用户访问,或者同一个用户不同时间访问同一个文件,每次都需要重新编译然后运行,这样就耗费了大量时间。

通过编译缓存每个文件在修改之后只编译一次这样就减少了文件IO操作,用户访问后机器指令直接从内存中取出并执行而不是硬盘中读出。

最常见的PHP编译缓存工具有:APC,Accelerator,xcache

2、 全局页面缓存– Squid Cache

Squid Cache(简称为Squid)是一个流行的自由软件(GNU通用公共许可证)的代理服务器和Web缓存服务器,Squid作为网页服务器的前置cache服务器通过缓存相关请求来提高Web服务器的速度。

3、 局部缓存之SQL缓存

在大多数应用程序中主要的瓶颈往往可以追溯到数据库的操作中,一般都是因为复杂的数据库查询而耗费了大量时间,而SQL缓存可以大大降低复杂查询造成的负荷。

SQL缓存的例子(使用了memcached扩展)

代码片段:

$key = md5(“some sort of sql query”);

if (!($result = memcache_get($key))) {

$result = $pdo->query($qry)->fetchAll();

// 缓存查询结果一小时

memcache_set($key, $result, NULL, 3600);

}

4、 局部缓存之代码块缓存

为了优化PHP程序,有时候我们不得不优化一个个代码段来减少那么一点点的执行的时间,但是比起优化复杂的不同的PHP代码段还不如通过缓存来直接忽略这些代码段的优化,这样做的好处是:

1)        能够很快的看到效果

2)        2、不会破坏以前的代码

3)        速度要比优化代码要快得多

代码块缓存的列子(同样使用了memcached扩展)

代码片段:

function complex_function_abc($a, $b, $c) {

$key = __FUNCTION__ . serialize

(func_get_args());

if (!($result = memcache_get($key))) {

$result = //函数代码

// 储存执行结果1小时

memcache_set($key, $result, NULL, 3600);

}

return $result;

}

当然除了上述方法外还可以用到文件缓存(将数据库中的数据取出储存在文件中),还可以生成静态HTML文件等,但是这些方法的缓存还是将文件储存在硬盘上而不是内存中。

输出控制

除了上述缓存技术外还可以通过输出控制来让程序执行的时间更少

下面通过PHP与APACHE来说说输出控制

1、PHP输出控制

这里最主要用到ob_start()以及PHP中的OB系列函数,这些函数可以做什么呢?

第一就是静态模版技术。所谓静态模版技术就是通过某种方式,使得用户在client端得到的是由PHP产生的html页面。如果这个html页面不会再被更新,那么当另外的用户再次浏览此页面时,程序将不会再调用PHP以及相关的数据库,对于某些信息量比较大的网站,例如sina,163,sohu。类似这种的技术带来的好处是非常巨大的。

代码示例:

<?php

ob_start(); //打开缓冲区

?>

php页面的全部输出

<?php

$content = ob_get_contents(); //取得php页面输出的全部内容

$fp = fopen(“output.html”, “w”); //创建一个文件,并打开,准备写入

fwrite($fp, $content); //把php页面的内容全部写入output.html,然后……

fclose($fp);

?>

当然这个ob系列函数还有其他很多用处我就不在这里一一说明了。

2、apache输出控制

将SendBufferSize设置为页面大小,这样就能将页面一次性放在发送缓冲区从而增加处理速度。

SendBufferSize 指令

说明:TCP发送缓冲区大小(字节)

语法:SendBufferSize bytes

默认值:SendBufferSize 0

作用域:server config

状态:MPM

模块:beos, mpm_netware, mpm_winnt, mpmt_os2, prefork, worker

这个指令设置服务器的TCP发送缓冲区的大小(字节)。提高这个值会导致两个后果:高速度和高潜伏时间(100ms左右)。如果设置为”0″,将使用操作系统默认值。

通过源代码方式编译你的Apache/PHP/Database 可让你的程序增加10–15%的速度

下面再说说在代码优化的时候应该注意的:

1、短代码不等于快的代码

很多人在写程序时希望将代码写的越简洁越好,但是越短的代码有时候反而需要更长的执行时间,所以哪怕是用更多的代码也不使用速度慢的代码

2、在写程序的时候更应该注重程序的扩展性,而不是追求速度

3、在优化你的代码之前,先看看跟数据库有关的部分,因为大多数应用程序的瓶颈在数据库而不是代码

4、微优化得不偿失

什么叫做微优化?就像前面所说的将正则表达式部分的代码改用字符串函数代替。这样做有以下缺点:

(1)   花费时间较长

(2)   不会解决你的性能问题

(3)   很有可能会破坏以前的代码从而产生未知的错误

(4)   付出大于回报

这里还不得不提到一个误区,有些人为了让程序更加优化,在分析业务逻辑的时候便将优化考虑在内了,从而为了得到更优的代码而改动业务逻辑。这是十分愚蠢的想法,因为程序的目的便是为了处理现实中遇到的问题,是为这些问题服务的,怎么能本末倒置呢。

时间: 2024-10-18 21:22:38

细说PHP优化那些事的相关文章

简单说说PHP优化那些事

我们在编写程序时,总是想要使自己的程序占用资源最小,运行速度更快,代码量更少.往往我们在追求这些的同时却失去了很多东西.下面我想讲讲我对PHP优化的理解.优化的目的是花最少的代价换来最快的运行速度与最容易维护的代码. 进行大范围的优化,而不是死啃某些程序代码 我这里所说的优化,基本上都是从服务器,Apache,数据库这些方面来进行的优化,而并不是对你的PHP代码加以改进从而提高程序的运行速度,因为比起你将程序中的正则优化为字符串处理函数从而提升程序速度来说,在大范围内进行的优化所需要的代价要比这

java内存优化牛刀小试

小猿做了两年的c++,上个月竟然被调到java项目,于是第一篇随笔就想八一八java的内存优化. 首先优化这种事,肯定是应该放到最后去做的,不过在写代码的过程中养成良好的习惯也是很重要的.在这里先推荐一本书<编写高质量代码:改善Java程序的151个建议.秦小波>. 首先,在写代码的时候,尽量少用对象,能用基本变量代替的就用基本变量,这点下面会举例. 其次,很多时候你想做一个功能,写一段代码,不是用时间换空间就是用空间换时间.要根据这个功能到底是看中时间,还是看中空间,常访问到的必然是要放到内

《Python学习之路 -- 网络编程》

在前面已经提到过,互联网的本质就是一堆协议,协议就是标准,比如全世界人通信的标准是英语,所有的计算机都学会了互联网协议,那么所有的计算机就可以按照统一的标准去收发信息完成通信了. 作为普通开发人员的我们,写的软件/程序都是处于应用层上的,然而,想要让软件接入互联网,就必须得通过传输层,也就是必须遵循TCP协议或者UDP协议.这是两个非常复杂的协议,如果遵循原生的协议,那么必然会大大降低效率,所以就有了socket抽象层的概念.socket是应用层与TCP/IP协议族通信的软件抽象层,它是一组接口

Node.js和PHP运行机制对比

为什么要用node.js它又有什么优势呢?一个新的技术被大家喜爱那么它就必然有它的优势,那么下面我们就来简单把它和php做一个对比 1 . Node.js 他用的是JavaScript引擎,那么注定它是单线程 ,使用异步方法开辟多个任务,无需像php等待上个任务线程使用结束之后给下个使用,  PHP也是单线程但是它借用Apache服务器提供多线程服务 2 . 高并发,大数据量怎么处理: php : 优化sql ,用组件,用缓存,为了让线程尽快结束,进行下一次任务 node:单线程 .异步.事件驱

node基础01:简要介绍

1.node vs php 优点 性能高(机制问题) 开发效率高(省了不少优化的事) 应用范围广(可以开发桌面系统,electron框架) 缺点 新,人少 中间件少 IDE不完善 2.node的劣势和解决方案 默认不支持多核,使用cluster可以解决 默认不支持服务器集群,node-http-proxy可以解决 使用nginx做负载均衡,静态的由nginx处理,动态由node处理 forever或node-cluster实现灾难恢复 3.框架选择 比较热门的框架有:express,koa,Ha

EF应用带来的好处

让大家看一下改版前的代码和我改版之后的代码.你就明白了.. 背景:有学生表,也有一张班级表.通过在学生表中加入外键班级ID.现在我需要查询到学生表的信息 并查询到相关的班级信息 同时保存在学生的数据契约中. 改版前: 代码块一: #region (考试接口)查询所有的在校学生+List<Student> QueryAllStudent() /// <summary> /// (考试接口)查询所有的在校学生 包括班级名称 /// </summary> /// <re

node.js学习笔记(1)——什么是node.js?

什么是node.js? nodejs是编写高性能网络服务器的JavaScript工具包(用于js开发服务端程序) 单线程.异步.事件驱动 特点:快,耗内存多 网上一个百万级的并发测试,未优化的情况下消耗16G内存,原因在于其单线程轮询过后的事件异步处理,每一个异步事件开辟一块内存区域. node.js vs php 优点: 性能高(机制问题) 开发效率高(省不少优化的事) 应用范围广,可以开发桌面系统,electron框架 缺点: 新,人少 中间件少 IDE不完善 node.js的劣势和解决方案

第一章:node.js简述

什么是nodejs nodejs从性能上来说是编写高性能网络服务器的JavaScript工具包.(翻译过来就是:用js开发服务端程序) 1.单线程.异步.事件驱动. 2.特点是:快.耗内存多. 3.异步消除内存测试: 网上一百万级并发测试,未优化的情况下消耗了16G内存. 如何理解nodejs执行速度快,但耗内存多的特点 PHP的知识点 PHP本身是不支持多线程的,是因为PHP的服务器Apache本身支持多线程.当Apache启动的时候,它先提供150个线程给PHP,假设在并发的条件下,打比方也

数据库设计(6/9):存储过程主体

对于设计和创建数据库完全是个新手?没关系,Joe Celko, 世界上读者数量最多的SQL作者之一,会告诉你这些基础.和往常一样,即使是最专业的数据库老手,也会给他们带来惊喜.Joe是DMBS杂志是多年来最受 读者喜爱的作者.他在美国.英国,北欧,南美及非洲传授SQL知识.他在ANSI / ISO SQL标准委员会工作了10年,为SQL-89和SQL-92标准做出了杰出贡献. 在上一篇文章里已经介绍了SQL Server里的存储过程标题,Joe会继续谈下存储过程内容的话题.在这篇文章里,他会概况