您好,登錄后才能下訂單哦!
這篇文章給大家介紹怎么在php中使用APCu擴展,內容非常詳細,感興趣的小伙伴們可以參考借鑒,希望對大家能有所幫助。
APCu 擴展是 APC 擴展的升級,APC 擴展已經不維護了。這兩套擴展其實都是基于 opcode caching 。也就是 PHP 自身的 opcode 來實現的緩存能力。
APCu 的安裝就和普通的 PHP 擴展一樣,非常簡單,最主要的是這個擴展還非常的小。不管下載還是安裝都是秒級可以完成的。所以說能夠非常方便的應用于小規模的項目,而且是 PHP 原生支持的,不需要額外的端口之類的配置。
緩存系統一般都會有的增加、刪除、查詢、自增等功能都在 APCu 擴展中有對應的實現。
apcu_add — 創建一個新的緩存
apcu_cache_info — 查看 APCu 的全部緩存信息
apcu_cas — 更新一個緩存的值為新值
apcu_clear_cache — 清除全部的緩存
apcu_dec — 自減緩存值
apcu_delete — 刪除一個緩存的內容
apcu_enabled — 當前環境下是否啟用 APCu 緩存
apcu_entry — 原子地生成一個緩存實體
apcu_exists — 檢查緩存是否存在
apcu_fetch — 查詢緩存
apcu_inc — 自增緩存值
apcu_sma_info — 查詢緩存的共享內存信息
apcu_store — 保存一個緩存
apcu_add("int", 1); apcu_add("string", "I'm String"); apcu_add("arr", [1,2,3]); class A{ private $apc = 1; function test(){ echo "s"; } } apcu_add("obj", new A); var_dump(apcu_fetch("int")); var_dump(apcu_fetch("string")); var_dump(apcu_fetch("arr")); var_dump(apcu_fetch("obj"));
正常的使用都是比較簡單的,我們添加各種類型的數據都可以正常存入緩存。不過需要注意的是,我們可以直接保存對象進入 APCu 緩存中,不需要將它序列化或者JSON成字符串,系統會自動幫我們序列化。
apcu_add(string \$key , mixed $var [, int $ttl = 0 ]) 方法就是普通的添加一個緩存,$ttl 可以設置過期時間,也是以秒為單位,如果不設置就是長期有效的。注意,APCu 的緩存時限在一次 CLI 中有效,再調用一次 CLI 取不到上次 CLI 中設置的緩存內容。而在 PHP-FPM 中,重啟 PHP-FPM 或 FastCGI 之后緩存會失效。
接下來我們重點測試一下幾個不太常見的方法。
apcu_cas("int", 1, 2); var_dump(apcu_fetch("int")); // Warning apcu_cas() expects parameter 2 to be int apcu_cas("string", "I'm String", "I'm New String");
apcu_cas(string $key , int $old , int $new) 是將一個 $old 值修改為 $new 值,它只能修改數字類型的內容,如果是字符串的修改會報錯。這個函數有什么優勢呢?它最大的優勢是原子性的,也就是不受高并發的影響。與之類似的是 apcu_store(string $key , mixed $var [, int $ttl = 0 ]) 方法,不過這個方法只是簡單的修改一個緩存的內容,如果這個緩存的鍵不存在的話,就新建一個,它不受類型的限制,當然也不具有原子性。
apcu_entry("entry", function($key){ return "This is " . $key; }); var_dump(apcu_fetch("entry"));
apcu_entry(string $key , callable $generator [, int $ttl = 0 ]) 這個函數的作用是如果 $key 這個緩存不存在,則執行 $generator 這個匿名函數,并將 $key 做為鍵值傳遞進去,然后生成也就是 return 一個內容做為這個緩存的值。
var_dump(apcu_cache_info());
關于怎么在php中使用APCu擴展就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。