APC 缓存
alternative php cache(APC)是 php 的一个免费公开的优化代码缓存。它用来提供免费,公开并且强健的架构来缓存和优化 php 的中间代码。
在 windows 下,apc 要求有 c:\tmp 目录,并且该目录要对 web 服务器进程可写。
A. 安装:
以php extension 形式安装.
B. 配置
apc.enabled boolean apc.optimization optimization
选项在脚本中可以改变
[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 ; 关于该指令目前尚无说明文档,参见:http://pecl.php.net/bugs/bug.php?id=8754 ; 请保持为off,否则可能导致意想不到的结果。 apc.max_file_size = 1m ;sys ; 禁止大于此尺寸的文件被缓存。 apc.mmap_file_mask = ;sys ; 如果使用–enable-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字段值)。
C. 函数
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
apc的用法比较简单, 只有几个函数,列举如下:
apc_cache_info()返回缓存信息apc_clear_cache()清除apc缓存内容, 默认(无参数)时,只清除系统缓存,要清除用户缓存,需用 user 参数。apc_define_constants( string key, array constants [, bool case_sensitive] )将数组constants以常量加入缓存。apc_load_constants (string key)取出常量缓存。apc_store ( string key, mixed var [, int ttl] )在缓存中保存数据。apc_fetch ( string key )获得apc_store保存的缓存内容apc_delete ( string key )删除apc_store保存的内容
D. APC 的管理:
到 pecl.php.net 下载 apc 源码包有个apc.php,copy到 web server 可以访问到的地方,浏览即可访问。
管理界面功能有:
- refresh data
- view host stats
- System cache entries
- user cache entries
- version check