首頁 >後端開發 >php教程 >php apc你了解多少?

php apc你了解多少?

WBOY
WBOY原創
2016-07-25 08:59:591075瀏覽
為大家介紹php apc的相關知識,包括apc常用函數、apc常配置、apc的優點等,並舉了一個不錯的例子,有需要的朋友,可以參考下。

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不協議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
/**
*php apc示例
* by http://bbs.it-home.org
*/
$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欄位值)。



陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn