APC
的具体配置。
Alternative PHP Cache(
APC)是
PHP 的一个免费公开的优化代码缓存。它用来提供免费,公开并且强健的架构来缓存和优化
PHP 的中间代码。
APC 官方网站为
http://pecl.php.net/package/apc
1、安装
以
PHP extension 形式安装
phpize
./configure --enable-apc --enable-apc-mmap
make
make install
生成
.so,将
.so拷贝到
php引用
modules的目录下,修改权限
755
2、配置
apc.enabled
boolean
apc.optimization
optimization
选项在脚本中可以改变
APC PHP.ini配置选项详解
[APC]
; Alternative PHP Cache 用于缓存和优化
PHP中间代码
apc.cache_by_default
= On
;SYS
; 是否默认对所有文件启用缓冲。
; 若设为
Off并与以加号开头的
apc.filters指令一起用,则文件仅在匹配过滤器时才被缓存。
apc.enable_cli
= Off
;SYS
; 是否为
CLI版本启用
APC功能,仅用于测试和调试目的才打开此指令。
apc.enabled
= On
; 是否启用
APC,如果
APC被静态编译进
PHP又想禁用它,这是唯一的办法。
apc.file_update_protection
= 2
;SYS
; 当你在一个运行中的服务器上修改文件时,你应当执行原子操作。
; 也就是先写进一个临时文件,然后将该文件重命名
(mv)到最终的名字。
; 文本编辑器以及
cp, tar 等程序却并不是这样操作的,从而导致有可能缓冲了残缺的文件。
; 默认值
2 表示在访问文件时如果发现修改时间距离访问时间小于
2 秒则不做缓冲。
; 那个不幸的访问者可能得到残缺的内容,但是这种坏影响却不会通过缓存扩大化。
; 如果你能确保所有的更新操作都是原子操作,那么可以用
0 关闭此特性。
; 如果你的系统由于大量的
IO操作导致更新缓慢,你就需要增大此值。
apc.filters
=
;SYS
; 一个以逗号分隔的
POSIX扩展正则表达式列表。
; 如果源文件名与任意一个模式匹配,则该文件不被缓存。
; 注意,用来匹配的文件名是传递给
include/require的文件名,而不是绝对路径。
; 如果正则表达式的第一个字符是
"+"则意味着任何匹配表达式的文件会被缓存,
; 如果第一个字符是
"-"则任何匹配项都不会被缓存。
"-"是默认值,可以省略掉。
apc.ttl
= 0
;SYS
; 缓存条目在缓冲区中允许逗留的秒数。
0 表示永不超时。建议值为
7200~36000。
; 设为
0 意味着缓冲区有可能被旧的缓存条目填满,从而导致无法缓存新条目。
apc.user_ttl
= 0
;SYS
; 类似于
apc.ttl,只是针对每个用户而言,建议值为
7200~36000。
; 设为
0 意味着缓冲区有可能被旧的缓存条目填满,从而导致无法缓存新条目。
apc.gc_ttl
= 3600
;SYS
; 缓存条目在垃圾回收表中能够存在的秒数。
; 此值提供了一个安全措施,即使一个服务器进程在执行缓存的源文件时崩溃,
; 而且该源文件已经被修改,为旧版本分配的内存也不会被回收,直到达到此
TTL值为止。
; 设为零将禁用此特性。
apc.include_once_override
= Off
;SYS
; 请保持为
Off,否则可能导致意想不到的结果。
apc.max_file_size
= 1M
;SYS
; 禁止大于此尺寸的文件被缓存。
apc.mmap_file_mask
=
;SYS
; 如果使用
�Cenable-mmap(默认启用
)为
APC编译了
MMAP支持,
; 这里的值就是传递给
mmap模块的
mktemp风格的文件掩码
(建议值为
"/tmp/apc.XXXXXX")。
; 该掩码用于决定内存映射区域是否要被
file-backed或者
shared memory backed。
; 对于直接的
file-backed内存映射,要设置成
"/tmp/apc.XXXXXX"的样子
(恰好
6个
X)。
; 要使用
POSIX风格的
shm_open/mmap就需要设置成
"/apc.shm.XXXXXX"的样子。
; 你还可以设为
"/dev/zero"来为匿名映射的内存使用内核的
"/dev/zero"接口。
; 不定义此指令则表示强制使用匿名映射。
apc.num_files_hint
= 1000
;SYS
; Web服务器上可能被包含或被请求的不同源文件的大致数量
(建议值为
1024~4096)。
; 如果你不能确定,则设为
0 ;此设定主要用于拥有数千个源文件的站点。
apc.optimization
= 0
; 优化级别
(建议值为
0 ) 。
; 正整数值表示启用优化器,值越高则使用越激进的优化。
; 更高的值可能有非常有限的速度提升,但目前尚在试验中。
apc.report_autofilter
= Off
;SYS
; 是否记录所有由于
early/late binding原因而自动未被缓存的脚本。
apc.shm_segments
= 1
;SYS
; 为编译器缓冲区分配的共享内存块数量
(建议值为
1)。
; 如果
APC耗尽了共享内存,并且已将
apc.shm_size指令设为系统允许的最大值,
; 你可以尝试增大此值。
apc.shm_size
= 30
;SYS
; 每个共享内存块的大小
(以
MB为单位,建议值为
128~256)。
; 有些系统
(包括大多数
BSD变种
)默认的共享内存块大小非常少。
apc.slam_defense
= 0
;SYS(反对使用该指令,建议该用
apc.write_lock指令
)
; 在非常繁忙的服务器上,无论是启动服务还是修改文件,
; 都可能由于多个进程企图同时缓存一个文件而导致竞争条件。
; 这个指令用于设置进程在处理未被缓存的文件时跳过缓存步骤的百分率。
; 比如设为
75表示在遇到未被缓存的文件时有
75%的概率不进行缓存,从而减少碰撞几率。
; 鼓励设为
0 来禁用这个特性。
apc.stat
= On
;SYS
; 是否启用脚本更新检查。
; 改变这个指令值要非常小心。
; 默认值
On 表示
APC在每次请求脚本时都检查脚本是否被更新,
;
如果被更新则自动重新编译和缓存编译后的内容。但这样做对性能有不利影响。
; 如果设为
Off 则表示不进行检查,从而使性能得到大幅提高。
;
但是为了使更新的内容生效,你必须重启Web服务器。
;
这个指令对于include/require的文件同样有效。但是需要注意的是,
;
如果你使用的是相对路径,APC就必须在每一次include/require时都进行检查以定位文件。
; 而使用绝对路径则可以跳过检查,所以鼓励你使用绝对路径进行
include/require操作。
apc.user_entries_hint
= 100
;SYS
; 类似于
num_files_hint指令,只是针对每个不同用户而言。
; 如果你不能确定,则设为
0 。
apc.write_lock
= On
;SYS
; 是否启用写入锁。
; 在非常繁忙的服务器上,无论是启动服务还是修改文件,
; 都可能由于多个进程企图同时缓存一个文件而导致竞争条件。
; 启用该指令可以避免竞争条件的出现。
apc.rfc1867
= Off
;SYS
; 打开该指令后,对于每个恰好在
file字段之前含有
APC_UPLOAD_PROGRESS字段的上传文件,
APC都将自动创建一个
upload_的用户缓存条目
(就是
APC_UPLOAD_PROGRESS字段值
)。
3、
php函数
apc_cache_info
- Retrieves cached information (and meta-data) from APC's data store
apc_clear_cache - Clears the APC cache
apc_define_constants - Defines a set of constants for later retrieval and mass-definition
apc_delete - Removes a stored variable from the cache
apc_fetch - Fetch a stored variable from the cache
apc_load_constants - Loads a set of constants from the cache
apc_sma_info - Retrieves APC's Shared Memory Allocation information
apc_store - Cache a variable in the data store
4、注意:
Apc与
apache的进程共享内存,所以只有在执行
apache进程时,才可以往
apc中存值,普通的
php进程不能访问
apc共享内存。
提高
PHP
性能的编码技巧(一)
0
、用单引号代替双引号来包含字符串,这样做会更快一些。因为
PHP
会在双引号包围的字符串中搜寻变量,单引号则不会,注意:只有
echo
能这么做,它是
一种可以把多个字符串当作参数的
“
函数
”
(译注:
PHP
手册中说
echo
是语言结构,不是真正的函数,故把函数加上了双引号)。
1
、如果能将类的方法定义成
static
,就尽量定义成
static
,它的速度会提升将近
4
倍。
2
、
$row[’id’]
的速度是
$row[id]
的
7
倍。
3
、
echo
比
print
快,并且使用
echo
的多重参数(译注:指用逗号而不是句点)代替字符串连接,比如
echo $str1,$str2
。
4
、在执行
for
循环之前确定最大循环数,不要每循环一次都计算最大值,最好运用
foreach
代替。
5
、注销那些不用的变量尤其是大数组,以便释放内存。
6
、尽量避免使用
__get
,
__set
,
__autoload
。
7
、
require_once()
代价昂贵。
8
、
include
文件时尽量使用绝对路径,因为它避免了
PHP
去
include_path
里查找文件的速度,解析操作系统路径所需的时间会更少。
9
、如果你想知道脚本开始执行(译注:即服务器端收到客户端请求)的时刻,使用
$_SERVER[‘REQUEST_TIME’]
要好于
time()
。
10
、函数代替正则表达式完成相同功能。
11
、
str_replace
函数比
preg_replace
函数快,但
strtr
函数的效率是
str_replace
函数的四倍。
12
、如果一个字符串替换函数,可接受数组或字符作为参数,并且参数长度不太长,那么可以考虑额外写一段替换代码,使得每次传递参数是一个字符,而不是只写一行代码接受数组作为查询和替换的参数。
13
、使用选择分支语句(译注:即
switch case
)好于使用多个
if
,
else if
语句。
14
、用
@
屏蔽错误消息的做法非常低效,极其低效。
15
、打开
apache
的
mod_deflate
模块,可以提高网页的浏览速度。
16
、数据库连接当使用完毕时应关掉,不要用长连接。
17
、错误消息代价昂贵。
18
、在方法中递增局部变量,速度是最快的。几乎与在函数中调用局部变量的速度相当。
19
、递增一个全局变量要比递增一个局部变量慢
2
倍。
20
、递增一个对象属性(如:
$this->prop++
)要比递增一个局部变量慢
3
倍。
21
、递增一个未预定义的局部变量要比递增一个预定义的局部变量慢
9
至
10
倍。
22
、仅定义一个局部变量而没在函数中调用它,同样会减慢速度(其程度相当于递增一个局部变量)。
PHP
大概会检查看是否存在全局变量。
23
、方法调用看来与类中定义的方法的数量无关,因为我(在测试方法之前和之后都)添加了
10
个方法,但性能上没有变化。
24
、派生类中的方法运行起来要快于在基类中定义的同样的方法。
25
、调用带有一个参数的空函数,其花费的时间相当于执行
7
至
8
次的局部变量递增操作。类似的方法调用所花费的时间接近于
15
次的局部变量递增操作。
26
、
Apache
解析一个
PHP
脚本的时间要比解析一个静态
HTML
页面慢
2
至
10
倍。尽量多用静态
HTML
页面,少用脚本。
27
、除非脚本可以缓存,否则每次调用时都会重新编译一次。引入一套
PHP
缓存机制通常可以提升
25%
至
100%
的性能,以免除编译开销。
28
、尽量做缓存,可使用
memcached
。
memcached
是一款高性能的内存对象缓存系统,可用来加速动态
Web
应用程序,减轻数据库负载。对运算码
(OP code)
的缓存很有用,使得脚本不必为每个请求做重新编译。
29
、当操作字符串并需要检验其长度是否满足某种要求时,你想当然地会使用
strlen()
函数。此函数执行起来相当快,因为它不做任何计算,只返回在
zval
结构(
C
的内置数据结构,用于存储
PHP
变量)中存储的已知字符串长度。但是,由于
strlen()
是函数,多多少少会有些慢,因为函数调用会经过诸多步
骤,如字母小写化(译注:指函数名小写化,
PHP
不区分函数名大小写)、哈希查找,会跟随被调用的函数一起执行。在某些情况下,你可以使用
isset()
技巧加速执行你的代码。
(举例如下)
if (strlen($foo) < 5) { echo “Foo is too short”$$ }
(与下面的技巧做比较)
if (!isset($foo{5})) { echo “Foo is too short”$$ }
调用
isset()
恰巧比
strlen()
快,因为与后者不同的是,
isset()
作为一种语言结构,意味着它的执行不需要函数查找和字母小写化。也就是说,实际上在检验字符串长度的顶层代码中你没有花太多开销。
34
、当执行变量
$i
的递增或递减时,
$i++
会比
++$i
慢一些。这种差异是
PHP
特有的,并不适用于其他语言,所以请不要修改你的
C
或
Java
代码并
指望它们能立即变快,没用的。
++$i
更快是因为它只需要
3
条指令
(opcodes)
,
$i++
则需要
4
条指令。后置递增实际上会产生一个临时变量,这个临时变量随后被递增。而前置递增直接在原值上递增。这是最优化处理的一种,正如
Zend
的
PHP
优化器所作的那样。牢记这个优化处理不失为一个好主意,因为并不是所有的指令优化器都会做同样的优化处理,并且存在大量没有装配指令优化器的互联网服务提
供商(
ISPs
)和服务器。
35
、并不是事必面向对象
(OOP)
,面向对象往往开销很大,每个方法和对象调用都会消耗很多内存。
36
、并非要用类实现所有的数据结构,数组也很有用。
37
、不要把方法细分得过多,仔细想想你真正打算重用的是哪些代码?
38
、当你需要时,你总能把代码分解成方法。