apc定義:apc是一個開放自由的php opcode緩存。它的目標是提供一個自由、開放和健全的框架,用於緩存和優化php中間代碼。
apc常用函數: 1.apc_clear_cache() 清楚apc緩存內容
2.apc_define_constants(string key,array constants,[,bool case_sensitive]) 將數組constants以常量加入緩存
3.apc_load_constants(string key) 取出常量緩存
4.apc_store(string key,mixed var [, int ttl]) 在緩存中保存數據
5.apc_fetch(string key) 獲取apc_store保存的緩存數據
6.apc_delete(string key) 刪除apc_store保存的內容
7.apc_add(string key,mixd var [, int ttl]) 緩存一個變量到數據存儲(只在變量之前沒有被存儲的情況)
8.apc_exists(mix keys) 檢查是否有一個或者多個apc鍵名存在
9.apc_delete_file(mixed keys) 從opcode緩存中刪除給定文件的緩存
10.apc_compile_file(string filename [,bool atmic=true]) 繞過filters的限制,緩存文件
11.apc_cache_info(string cache_type [,bool limited=false]) 獲取緩存i型奶昔
注:apc_clear_cache只清除opcode緩存文件,apc_delete清楚緩存中的變量;預定義變量,可以使用apc_define_constants函數;php變量可以使用函數apc_store,使用apc比memcache會更好,不需要經過網絡傳輸協議tcp;apc不適用於通過函數apc_store緩存頻繁變更的用戶數據,會出現一些奇異的現象;apc本身不支持分布式。
apc常用配置:
1.多少內存將被分配給apc,ini選項apc.shm_size(integer)控制這個設置。默認為30M
2.每次請求apc是否檢查文件修改,ini選項apc.stat控制這個設置,默認值為1,表示每次請求腳本時都減產腳本是否被更新,如果更新則自動重新編譯和緩存編譯後的內容,對性能有比例的影響,故這個設為0
3.通過ini選項apc.filters緩存更少的腳本
apc優點:
1.使用spinlocks(自旋)鎖機制,能夠達到最佳性能
2.apc提供apc.php,用於監控和管理apc緩存。(注:修改管理員名和密碼)
3.apc默認通過mmap匿名映射創建共享內存,緩存對象都存放在這塊大型的內存空間。由apc自行管理該共享內存
4.調整apc.shm_size、apc.num_files_hints、apc.user_entires_hint的值到最佳
5.php預定義常量,可以使用apc _define——constants()函數。不過apc開發者說pecl hidef性能更加,拋棄define,它是低效的
6.apc_store,對於系統設置等PHP變量,生命周期是整個應用(從httpd守護進程到httpd守護進程關閉),使用apc比memcache更好。(不需要經過網絡傳輸協議)
7.apc不適用於通過函數apc_store()緩存頻繁變更用戶數據,會出現一些奇異現象。
例:
<?php
$constants = array('APC_FILE'=>'apc.php','AUTHOR'=>'tim');
apc_define_constants('memb',$constants );
apc_load_constants('memb');
//echo APC_FILE;
//echo AUTHOR;
if(!apc_fetch('time1')) apc_store('time1',time());
if(!apc_fetch('time2')) apc_store('time2',time(),2);
//echo apc_fetch('time1');
//echo apc_fetch('time2');
class a{
public function b(){echo 'success';}
}
apc_store('obj',new a());
$a = apc_fetch('obj');
//$a-b();
$ret = apc_exists(array('foo', 'donotexist', 'bar'));
//array(2) { ["foo"]=> bool(true) ["bar"]=> bool(true) }
?>
補充詳細配置說明:
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字段值)。