溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

如何在PHP中安裝與使用APC

發(fā)布時(shí)間:2021-02-24 16:50:59 來(lái)源:億速云 閱讀:146 作者:Leah 欄目:開發(fā)技術(shù)

如何在PHP中安裝與使用APC?針對(duì)這個(gè)問題,這篇文章詳細(xì)介紹了相對(duì)應(yīng)的分析和解答,希望可以幫助更多想解決這個(gè)問題的小伙伴找到更簡(jiǎn)單易行的方法。

一、PHPAPC安裝
下載與解壓安裝包:

復(fù)制代碼 代碼如下:


wget-c http://pecl.php.net/get/APC-3.1.13.tgz
tar-zvxf APC-3.1.13.tgz
cdAPC-3.1.13


編譯安裝:

復(fù)制代碼 代碼如下:


wget-c http://pecl.php.net/get/APC-3.1.13.tgz
/usr/local/php/bin/phpize
./configure--enable-apc --enable-mmap --enable-apc-spinlocks--disable-apc-pthreadmutex--with-php-config=/usr/local/php/bin/php-config
make
sudomake install


修改php.ini加入:

復(fù)制代碼 代碼如下:


 extension= "apc.so" ;
;APCsetting
apc.enabled= 1
apc.shm_segments= 1
apc.shm_size= 64M
apc.optimization= 1
apc.num_files_hint= 0
apc.ttl= 0
apc.gc_ttl= 3600
apc.cache_by_default= on


重啟apache或者/usr/local/php/sbin/php-fpmrestart

二、PHPAPC配置選項(xiàng)
[APC]
;Alternative PHP Cache用于緩存和優(yōu)化PHP中間代碼
apc.cache_by_default= On
;是否默認(rèn)對(duì)所有文件啟用緩沖。
;若設(shè)為Off并與以加號(hào)開頭的apc.filters指令一起用,則文件僅在匹配過濾器時(shí)才被緩存。
apc.enable_cli= Off
;是否為CLI版本啟用APC功能,僅用于測(cè)試和調(diào)試目的才打開此指令。
apc.enabled= On
;是否啟用APC,如果APC被靜態(tài)編譯進(jìn)PHP又想禁用它,這是唯一的辦法。
apc.file_update_protection= 2
;當(dāng)你在一個(gè)運(yùn)行中的服務(wù)器上修改文件時(shí),你應(yīng)當(dāng)執(zhí)行原子操作。
;也就是先寫進(jìn)一個(gè)臨時(shí)文件,然后將該文件重命名(mv)到最終的名字。
;文本編輯器以及cp,tar 等程序卻并不是這樣操作的,從而導(dǎo)致有可能緩沖了殘缺的文件。
;默認(rèn)值2表示在訪問文件時(shí)如果發(fā)現(xiàn)修改時(shí)間距離訪問時(shí)間小于2秒則不做緩沖。
;那個(gè)不幸的訪問者可能得到殘缺的內(nèi)容,但是這種壞影響卻不會(huì)通過緩存擴(kuò)大化。
;如果你能確保所有的更新操作都是原子操作,那么可以用0關(guān)閉此特性。
;如果你的系統(tǒng)由于大量的IO操作導(dǎo)致更新緩慢,你就需要增大此值。
apc.filters=
;一個(gè)以逗號(hào)分隔的POSIX擴(kuò)展正則表達(dá)式列表。
;如果源文件名與任意一個(gè)模式匹配,則該文件不被緩存。
;注意,用來(lái)匹配的文件名是傳遞給include/require的文件名,而不是絕對(duì)路徑。
;如果正則表達(dá)式的第一個(gè)字符是"+"則意味著任何匹配表達(dá)式的文件會(huì)被緩存,
;如果第一個(gè)字符是"-"則任何匹配項(xiàng)都不會(huì)被緩存。"-"是默認(rèn)值,可以省略掉。
apc.ttl= 0
;緩存條目在緩沖區(qū)中允許逗留的秒數(shù)。0表示永不超時(shí)。建議值為7200~36000。
;設(shè)為0意味著緩沖區(qū)有可能被舊的緩存條目填滿,從而導(dǎo)致無(wú)法緩存新條目。
apc.user_ttl= 0
;類似于apc.ttl,只是針對(duì)每個(gè)用戶而言,建議值為7200~36000。
;設(shè)為0意味著緩沖區(qū)有可能被舊的緩存條目填滿,從而導(dǎo)致無(wú)法緩存新條目。
apc.gc_ttl= 3600
;緩存條目在垃圾回收表中能夠存在的秒數(shù)。
;此值提供了一個(gè)安全措施,即使一個(gè)服務(wù)器進(jìn)程在執(zhí)行緩存的源文件時(shí)崩潰,
;而且該源文件已經(jīng)被修改,為舊版本分配的內(nèi)存也不會(huì)被回收,直到達(dá)到此TTL值為止。
;設(shè)為零將禁用此特性。
apc.include_once_override= Off
;請(qǐng)保持為Off,否則可能導(dǎo)致意想不到的結(jié)果。
apc.max_file_size= 1M
;禁止大于此尺寸的文件被緩存。
apc.mmap_file_mask=
;如果使用–enable-mmap(默認(rèn)啟用)為APC編譯了MMAP支持,
;這里的值就是傳遞給mmap模塊的mktemp風(fēng)格的文件掩碼(建議值為"/tmp/apc.XXXXXX")。
;該掩碼用于決定內(nèi)存映射區(qū)域是否要被file-backed或者sharedmemory backed。
;對(duì)于直接的file-backed內(nèi)存映射,要設(shè)置成"/tmp/apc.XXXXXX"的樣子(恰好6個(gè)X)。
;要使用POSIX風(fēng)格的shm_open/mmap就需要設(shè)置成"/apc.shm.XXXXXX"的樣子。
;你還可以設(shè)為"/dev/zero"來(lái)為匿名映射的內(nèi)存使用內(nèi)核的"/dev/zero"接口。
;不定義此指令則表示強(qiáng)制使用匿名映射。
apc.num_files_hint= 1000
;Web服務(wù)器上可能被包含或被請(qǐng)求的不同源文件的大致數(shù)量(建議值為1024~4096)。
;如果你不能確定,則設(shè)為0;此設(shè)定主要用于擁有數(shù)千個(gè)源文件的站點(diǎn)。
apc.optimization= 0
;優(yōu)化級(jí)別(建議值為0 )。
;正整數(shù)值表示啟用優(yōu)化器,值越高則使用越激進(jìn)的優(yōu)化。
;更高的值可能有非常有限的速度提升,但目前尚在試驗(yàn)中。
apc.report_autofilter= Off
;是否記錄所有由于early/latebinding原因而自動(dòng)未被緩存的腳本。
apc.shm_segments= 1
;為編譯器緩沖區(qū)分配的共享內(nèi)存塊數(shù)量(建議值為1)。
;如果APC耗盡了共享內(nèi)存,并且已將apc.shm_size指令設(shè)為系統(tǒng)允許的最大值,
;你可以嘗試增大此值。
apc.shm_size= 30
;每個(gè)共享內(nèi)存塊的大小(以MB為單位,建議值為128~256)。
;有些系統(tǒng)(包括大多數(shù)BSD變種)默認(rèn)的共享內(nèi)存塊大小非常少。
apc.slam_defense= 0
;(反對(duì)使用該指令,建議該用apc.write_lock指令)
;在非常繁忙的服務(wù)器上,無(wú)論是啟動(dòng)服務(wù)還是修改文件,
;都可能由于多個(gè)進(jìn)程企圖同時(shí)緩存一個(gè)文件而導(dǎo)致競(jìng)爭(zhēng)條件。
;這個(gè)指令用于設(shè)置進(jìn)程在處理未被緩存的文件時(shí)跳過緩存步驟的百分率。
;比如設(shè)為75表示在遇到未被緩存的文件時(shí)有75%的概率不進(jìn)行緩存,從而減少碰撞幾率。
;鼓勵(lì)設(shè)為0來(lái)禁用這個(gè)特性。
apc.stat= On
;是否啟用腳本更新檢查。
;改變這個(gè)指令值要非常小心。
;默認(rèn)值On表示APC在每次請(qǐng)求腳本時(shí)都檢查腳本是否被更新,
;如果被更新則自動(dòng)重新編譯和緩存編譯后的內(nèi)容。但這樣做對(duì)性能有不利影響。
;如果設(shè)為Off則表示不進(jìn)行檢查,從而使性能得到大幅提高。
;但是為了使更新的內(nèi)容生效,你必須重啟Web服務(wù)器。
;這個(gè)指令對(duì)于include/require的文件同樣有效。但是需要注意的是,
;如果你使用的是相對(duì)路徑,APC就必須在每一次include/require時(shí)都進(jìn)行檢查以定位文件。
;而使用絕對(duì)路徑則可以跳過檢查,所以鼓勵(lì)你使用絕對(duì)路徑進(jìn)行include/require操作。
apc.user_entries_hint= 100
;類似于num_files_hint指令,只是針對(duì)每個(gè)不同用戶而言。
;如果你不能確定,則設(shè)為0。
apc.write_lock= On
;是否啟用寫入鎖。
;在非常繁忙的服務(wù)器上,無(wú)論是啟動(dòng)服務(wù)還是修改文件,
;都可能由于多個(gè)進(jìn)程企圖同時(shí)緩存一個(gè)文件而導(dǎo)致競(jìng)爭(zhēng)條件。
;啟用該指令可以避免競(jìng)爭(zhēng)條件的出現(xiàn)。
apc.rfc1867= Off
;打開該指令后,對(duì)于每個(gè)恰好在file字段之前含有

三、PHP_APC函數(shù)
apc_add
—緩存一個(gè)變量到數(shù)據(jù)存儲(chǔ)
apc_bin_dump— Get a binary dump of the given files and user variables
apc_bin_dumpfile— Output a binary dump of cached files and user variables to a file
apc_bin_load— Load a binary dump into the APC file/user cache
apc_bin_loadfile— Load a binary dump from a file into the APC file/user cache
apc_cache_info— Retrieves cached information from APC's data store
apc_cas— Updates an old value with a new value
apc_clear_cache—清除APC緩存
apc_compile_file— Stores a file in the bytecode cache, bypassing all filters.
apc_dec— Decrease a stored number
apc_define_constants— Defines a set of constants for retrieval and mass-definition
apc_delete_file— Deletes files from the opcode cache
apc_delete—從用戶緩存中刪除某個(gè)變量
apc_exists—檢查APC中是否存在某個(gè)或者某些key
apc_fetch—從緩存中取出存儲(chǔ)的變量
apc_inc—遞增一個(gè)儲(chǔ)存的數(shù)字
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

四、PHPAPC使用
使用apc緩存的示例(test_apc_cache.php):

復(fù)制代碼 代碼如下:


<?php
error_reporting(E_ALL);
classapcInit {
/**
*Apc緩存-設(shè)置緩存
*設(shè)置緩存key,value和緩存時(shí)間
*@param string $key KEY值
*@param string $value值
*@param string $time緩存時(shí)間
*/
publicstatic function set_cache($key, $value, $time = 0) {
if($time == 0) $time = null; //null情況下永久緩存
returnapc_store($key, $value, $time);;
}
/**
*Apc緩存-獲取緩存
*通過KEY獲取緩存數(shù)據(jù)
*@param string $key KEY值
*/
publicstatic function get_cache($key) {
returnapc_fetch($key);
}
/**
*Apc緩存-清除一個(gè)緩存
*從memcache中刪除一條緩存
*@param string $key KEY值
*/
publicstatic function clear($key) {
returnapc_delete($key);
}
/**
*Apc緩存-清空所有緩存
*不建議使用該功能
*@return
*/
publicstatic function clear_all() {
returnapc_clear_cache(); //清楚緩存
}
/**
*檢查APC緩存是否存在
*@param string $key KEY值
*/
publicstatic function exists($key) {
returnapc_exists($key);
}
/**
*字段自增-用于記數(shù)
*@param string $key KEY值
*@param int $step新增的step值
*/
publicstatic function inc($key, $step) {
returnapc_inc($key, (int) $step);
}
/**
*字段自減-用于記數(shù)
*@param string $key KEY值
*@param int $step新增的step值
*/
publicstatic function dec($key, $step) {
returnapc_dec($key, (int) $step);
}
/**
*緩存文件
*/
publicstatic function cache_file($file) {
returnapc_compile_file($file);
}
/**
*返回APC緩存信息
*/
publicstatic function info() {
returnapc_cache_info();
}
}
apc_clear_cache();
apcInit::cache_file("HessianUtils.php");
apcInit::cache_file("Hessian1Parser.php");
apcInit::cache_file("Hessian1Writer.php");
apcInit::cache_file("HessianStream.php");
apcInit::cache_file("HessianParsing.php");
apcInit::cache_file("HessianExceptions.php");
include_once"./HessianUtils.php";
include_once"./Hessian1Parser.php";
include_once"./Hessian1Writer.php";
include_once"./HessianStream.php";
include_once"./HessianParsing.php";
include_once"./HessianExceptions.php";
header("Content-type:text/html;charset=utf-8");
header("Cache-Control:private,max-age=0,no-cache");
$HessianWriter= new Hessian1Writer();
$array= array(1, 2, 3, array('sff','張三'));
//parser
$resolver= new HessianRuleResolver('./hessian1rules.php');
//解析array
$parser_array= new Hessian1Parser($resolver, newHessianStream($HessianWriter->writeValue($array)));
print_r($parser_array->parse());
?>


五、PHPAPC監(jiān)控與管理
APC提供了apc.php,用于監(jiān)控與管理APC緩存。將apc.php放到網(wǎng)站目錄中,修改賬號(hào)、密碼,即可通過瀏覽器監(jiān)控與管理APC緩存。
apc.php第41、42行:

復(fù)制代碼 代碼如下:


defaults('ADMIN_USERNAME','apc');// Admin Username
defaults('ADMIN_PASSWORD','password'); // Admin Password - CHANGE THIS TO ENABLE!!!

關(guān)于如何在PHP中安裝與使用APC問題的解答就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,如果你還有很多疑惑沒有解開,可以關(guān)注億速云行業(yè)資訊頻道了解更多相關(guān)知識(shí)。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI