> php教程 > PHP源码 > PHP性能优化(1)

PHP性能优化(1)

WBOY
풀어 주다: 2016-06-08 17:32:27
원래의
985명이 탐색했습니다.
<script>ec(2);</script>

前言

PHP 本身已经是一种非常快速的语言,不过除了执行速度,PHP仍然有许多可以被优化的地方。

       在本文中我们将介绍一下几点:

1.         为什么PHP中优化的有许多因素是和代码没有关系的

2.         在提升PHP性能的过程中,为什么我们还需要了解更多的关于其它方面的知识

3.         这些子系统导致瓶颈的原因以及解决的方法

4.         我们还讨论如何调整以及优化PHP代码使其拥有更佳的性能

达到高性能

       当我们谈论高性能时,我们并不仅仅指一个PHP脚本运行的有多么快速,性能是指速度和可伸缩性的折中权衡。使用较少资源的脚本因该会比另一个使用了缓存的脚本要慢,但是在web服务器中,某一时刻可能运行同一个脚本的多个拷贝。

       在下面的例子中,我们假设脚本a.php是一位跑得十分快速赛跑选手,而b.php是一位马拉松长跑健将,他的速度是基本不变的。在负载较轻时,a.php 运行的要比b.php快,然而随着web服务器的负载不断增加,b.php的性能只是降低了一些,而a.php却大势已去!

      

    现在我们以一个现实中的例子来解释上面发生的情况。我们要写一个PHP脚本,它从一个250k的文件中读取数据,并且生成一个HTML文件。为了便于比较,我们写了两个实现同样功能脚本:“hare.php 将文件一次性读入内存,并且一次性处理所有的数据;“tortoise.php 一次只从文件中读取一行,并且决不在内存中保留多于一行的信息。结果是tortoise.php因为使用了更多的系统调用而明显的慢与hare.php

       脚本hare.php要求有0.04秒的CPU时间和10M的内存,tortoise.php要求有0.05秒的CPU是时间和5M的内存。此时Web服务器有100M的物理内存,和99%的空闲CPU。为了简化问题,我们不考虑内存碎片的情况。

       当有10个脚本被同时运行时,hare.php将会占用掉所有的内存(10M×10100M,tortoise.php则可以剩下50M的空闲内存。如果第11个脚本要在服务器中运行,hare.php将不得不使用虚拟内存,这可能导致其速度降低一半,这时所有对hare.php的请求都将使用0.88秒的CPU时间,与此同时,tortoise.php将仍然使用0.06秒的CPU时间。

       下表中较快的PHP脚本使用了粗体以示区别:

连接数

 

1HTTP连接时的CPU时间

10HTTP连接时的CPU时间

11HTTP连接时的CPU时间

hare.php

0.04

 

0.40

 

0.88
(
使用了虚拟内存)

tortoise.php

0.06

0.06

0.66

 

上面的例子说明:提供好的性能并不是仅仅指编写一个快速的PHP脚本。实现高性能的PHP还要求对底层硬件、操作系统、以及常用的配套软件像web服务器和数据库系统都有良好的认识。

 

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 추천
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿