真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

php中apc的用法-創(chuàng)新互聯(lián)

本篇內(nèi)容介紹了“php中apc的用法”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠?qū)W有所成!

讓客戶滿意是我們工作的目標,不斷超越客戶的期望值來自于我們對這個行業(yè)的熱愛。我們立志把好的技術通過有效、簡單的方式提供給客戶,將通過不懈努力成為客戶在信息化領域值得信任、有價值的長期合作伙伴,公司提供的服務項目有:空間域名、網(wǎng)頁空間、營銷軟件、網(wǎng)站建設、安陸網(wǎng)站維護、網(wǎng)站推廣。

apc定義:apc是一個開放自由的php opcode緩存。它的目標是提供一個自由、開放和健全的框架,用于緩存和優(yōu)化php中間代碼。
apc常用函數(shù):
1.apc_clear_cache() 清楚apc緩存內(nèi)容
2.apc_define_constants(string key,array constants,[,bool case_sensitive])   將數(shù)組constants以常量加入緩存
3.apc_load_constants(string key) 取出常量緩存
4.apc_store(string key,mixed var [, int ttl])   在緩存中保存數(shù)據(jù)
5.apc_fetch(string key) 獲取apc_store保存的緩存數(shù)據(jù)
6.apc_delete(string key) 刪除apc_store保存的內(nèi)容
7.apc_add(string key,mixd var [, int ttl])  緩存一個變量到數(shù)據(jù)存儲(只在變量之前沒有被存儲的情況)
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函數(shù);php變量可以使用函數(shù)apc_store,使用apc比memcache會更好,不需要經(jīng)過網(wǎng)絡傳輸協(xié)議tcp;apc不適用于通過函數(shù)apc_store緩存頻繁變更的用戶數(shù)據(jù),會出現(xiàn)一些奇異的現(xiàn)象;apc本身不支持分布式。
apc常用配置:
1.多少內(nèi)存將被分配給apc,ini選項apc.shm_size(integer)控制這個設置。默認為30M
2.每次請求apc是否檢查文件修改,ini選項apc.stat控制這個設置,默認值為1,表示每次請求腳本時都減產(chǎn)腳本是否被更新,如果更新則自動重新編譯和緩存編譯后的內(nèi)容,對性能有比例的影響,故這個設為0
3.通過ini選項apc.filters緩存更少的腳本
apc優(yōu)點:
1.使用spinlocks(自旋)鎖機制,能夠達到很好性能
2.apc提供apc.php,用于監(jiān)控和管理apc緩存。(注:修改管理員名和密碼)
3.apc默認通過mmap匿名映射創(chuàng)建共享內(nèi)存,緩存對象都存放在這塊大型的內(nèi)存空間。由apc自行管理該共享內(nèi)存
4.調(diào)整apc.shm_size、apc.num_files_hints、apc.user_entires_hint的值到很好
5.php預定義常量,可以使用apc _define——constants()函數(shù)。不過apc開發(fā)者說pecl hidef性能更加,拋棄define,它是低效的
6.apc_store,對于系統(tǒng)設置等PHP變量,生命周期是整個應用(從httpd守護進程到httpd守護進程關閉),使用apc比memcache更好。(不需要經(jīng)過網(wǎng)絡傳輸協(xié)議)
7.apc不適用于通過函數(shù)apc_store()緩存頻繁變更用戶數(shù)據(jù),會出現(xiàn)一些奇異現(xiàn)象。
例:
$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功能,僅用于測試和調(diào)試目的才打開此指令。

apc.enabled = on
; 是否啟用apc,如果apc被靜態(tài)編譯進php又想禁用它,這是的辦法。

apc.file_update_protection = 2
;sys
; 當你在一個運行中的服務器上修改文件時,你應當執(zhí)行原子操作。
; 也就是先寫進一個臨時文件,然后將該文件重命名(mv)到最終的名字。
; 文本編輯器以及cp, tar 等程序卻并不是這樣操作的,從而導致有可能緩沖了殘缺的文件。
; 默認值2 表示在訪問文件時如果發(fā)現(xiàn)修改時間距離訪問時間小于2 秒則不做緩沖。
; 那個不幸的訪問者可能得到殘缺的內(nèi)容,但是這種壞影響卻不會通過緩存擴大化。
; 如果你能確保所有的更新操作都是原子操作,那么可以用0 關閉此特性。
; 如果你的系統(tǒng)由于大量的io操作導致更新緩慢,你就需要增大此值。

apc.filters =
;sys
; 一個以逗號分隔的posix擴展正則表達式列表。
; 如果源文件名與任意一個模式匹配,則該文件不被緩存。
; 注意,用來匹配的文件名是傳遞給include/require的文件名,而不是絕對路徑。
; 如果正則表達式的第一個字符是"+"則意味著任何匹配表達式的文件會被緩存,
; 如果第一個字符是"-"則任何匹配項都不會被緩存。"-"是默認值,可以省略掉。

apc.ttl = 0
;sys
; 緩存條目在緩沖區(qū)中允許逗留的秒數(shù)。0 表示永不超時。建議值為7200~36000。
; 設為0 意味著緩沖區(qū)有可能被舊的緩存條目填滿,從而導致無法緩存新條目。

apc.user_ttl = 0
;sys
; 類似于apc.ttl,只是針對每個用戶而言,建議值為7200~36000。
; 設為0 意味著緩沖區(qū)有可能被舊的緩存條目填滿,從而導致無法緩存新條目。

apc.gc_ttl = 3600
;sys
; 緩存條目在垃圾回收表中能夠存在的秒數(shù)。
; 此值提供了一個安全措施,即使一個服務器進程在執(zhí)行緩存的源文件時崩潰,
; 而且該源文件已經(jīng)被修改,為舊版本分配的內(nèi)存也不會被回收,直到達到此ttl值為止。
; 設為零將禁用此特性。

apc.include_once_override = off
;sys
; 關于該指令目前尚無說明文檔,參見:/tupian/20230522/search.php 請保持為off,否則可能導致意想不到的結(jié)果。

apc.max_file_size = 1m
;sys
; 禁止大于此尺寸的文件被緩存。

apc.mmap_file_mask =
;sys
; 如果使用–enable-mmap(默認啟用)為apc編譯了mmap支持,
; 這里的值就是傳遞給mmap模塊的mktemp風格的文件掩碼(建議值為"/tmp/apc.xxxxxx")。
; 該掩碼用于決定內(nèi)存映射區(qū)域是否要被file-backed或者shared memory backed。
; 對于直接的file-backed內(nèi)存映射,要設置成"/tmp/apc.xxxxxx"的樣子(恰好6個x)。
; 要使用posix風格的shm_open/mmap就需要設置成"/apc.shm.xxxxxx"的樣子。
; 你還可以設為"/dev/zero"來為匿名映射的內(nèi)存使用內(nèi)核的"/dev/zero"接口。
; 不定義此指令則表示強制使用匿名映射。

apc.num_files_hint = 1000
;sys
; web服務器上可能被包含或被請求的不同源文件的大致數(shù)量(建議值為1024~4096)。
; 如果你不能確定,則設為0 ;此設定主要用于擁有數(shù)千個源文件的站點。

apc.optimization = 0
; 優(yōu)化級別(建議值為0 ) 。
; 正整數(shù)值表示啟用優(yōu)化器,值越高則使用越激進的優(yōu)化。
; 更高的值可能有非常有限的速度提升,但目前尚在試驗中。

apc.report_autofilter = off
;sys
; 是否記錄所有由于early/late binding原因而自動未被緩存的腳本。

apc.shm_segments = 1
;sys
; 為編譯器緩沖區(qū)分配的共享內(nèi)存塊數(shù)量(建議值為1)。
; 如果apc耗盡了共享內(nèi)存,并且已將apc.shm_size指令設為系統(tǒng)允許的較大值,
; 你可以嘗試增大此值。

apc.shm_size = 30
;sys
; 每個共享內(nèi)存塊的大小(以mb為單位,建議值為128~256)。
; 有些系統(tǒng)(包括大多數(shù)bsd變種)默認的共享內(nèi)存塊大小非常少。

apc.slam_defense = 0
;sys(反對使用該指令,建議該用apc.write_lock指令)
; 在非常繁忙的服務器上,無論是啟動服務還是修改文件,
; 都可能由于多個進程企圖同時緩存一個文件而導致競爭條件。
; 這個指令用于設置進程在處理未被緩存的文件時跳過緩存步驟的百分率。
; 比如設為75表示在遇到未被緩存的文件時有75%的概率不進行緩存,從而減少碰撞幾率。
; 鼓勵設為0 來禁用這個特性。

apc.stat = on
;sys
; 是否啟用腳本更新檢查。
; 改變這個指令值要非常小心。
; 默認值on 表示apc在每次請求腳本時都檢查腳本是否被更新,
; 如果被更新則自動重新編譯和緩存編譯后的內(nèi)容。但這樣做對性能有不利影響。
; 如果設為 off 則表示不進行檢查,從而使性能得到大幅提高。
; 但是為了使更新的內(nèi)容生效,你必須重啟web服務器。
; 這個指令對于include/require的文件同樣有效。但是需要注意的是,
; 如果你使用的是相對路徑,apc就必須在每一次include/require時都進行檢查以定位文件。
; 而使用絕對路徑則可以跳過檢查,所以鼓勵你使用絕對路徑進行include/require操作。

apc.user_entries_hint = 100
;sys
; 類似于num_files_hint指令,只是針對每個不同用戶而言。
; 如果你不能確定,則設為0 。

apc.write_lock = on
;sys
; 是否啟用寫入鎖。
; 在非常繁忙的服務器上,無論是啟動服務還是修改文件,
; 都可能由于多個進程企圖同時緩存一個文件而導致競爭條件。
; 啟用該指令可以避免競爭條件的出現(xiàn)。

apc.rfc1867 = off
;sys
; 打開該指令后,對于每個恰好在file字段之前含有apc_upload_progress字段的上傳文件,
; apc都將自動創(chuàng)建一個upload_的用戶緩存條目(就是apc_upload_progress字段值)。


“php中apc的用法”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關的知識可以關注創(chuàng)新互聯(lián)網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實用文章!


分享名稱:php中apc的用法-創(chuàng)新互聯(lián)
轉(zhuǎn)載注明:http://weahome.cn/article/csejgi.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部