PHP高性能分布式內(nèi)存對(duì)象緩存系統(tǒng)擴(kuò)展Memcached的安裝及使用
memcached是一個(gè)高性能分布式的內(nèi)存對(duì)象緩存系統(tǒng), 通常被用于降低數(shù)據(jù)庫加載壓力以提高動(dòng)態(tài)web應(yīng)用的響應(yīng)速度。
此擴(kuò)展使用了libmemcached庫提供的api與memcached服務(wù)端進(jìn)行交互。它還提供了一個(gè)session處理器(memcached)。
關(guān)于memcached的安裝,可參考這篇文章:Ubuntu中memcached的安裝和配置。
在安裝php擴(kuò)展memcached之前,需要先安裝libmemcached,libmemcached是memcached的C/C++本地客戶端庫。
安裝libmemcached之前,還要先安裝libcloog-ppl0,否則編譯安裝過程中會(huì)出錯(cuò):
sudo apt-get install libcloog-ppl0
然后從這里http://libmemcached.org/libMemcached.html下載所需的libmemcached源碼安裝包,解壓到指定目錄,進(jìn)入該目錄,然后執(zhí)行以下指令:
./configure --prefix=/usr/local/libmemcachedmakesudo make install
然后就可以進(jìn)行php的memcached擴(kuò)展的安裝了,從這里下載所需的源碼安裝包:http://pecl.php.net/package/memcached,解壓到指定目錄,進(jìn)入該目錄,然后執(zhí)行以下指令:
phpize./configure --with-php-config=/usr/local/php/bin/php-config --with-libmemcached-dir=/usr/local/libmemcachedmakesudo make install
在安裝過程中可能會(huì)報(bào)錯(cuò):
未知類型名稱:memcached_server_instance_st
而導(dǎo)致make失敗,解決辦法如下:
在memcached擴(kuò)展解壓目錄下找到這個(gè)文件:php_libmemcached_compat.h,然后在其中添加下面這行
typedef const struct memcached_server_st *memcached_server_instance_st;
再次make,就OK了。
安裝成功后,在php.ini中添加extension=memcacached,然后重啟apache,查看phpinfo,看到如下部分
證明安裝成功。
二、超時(shí)時(shí)間一些存儲(chǔ)命令在發(fā)送時(shí)會(huì)包含一個(gè)失效值(與一個(gè)元素或一個(gè)客戶端操作請(qǐng)求相關(guān))到服務(wù)端。所有這類用法,實(shí)際發(fā)送的值可以 是一個(gè)Unix時(shí)間戳(自1970年1月1日起至失效時(shí)間的整型秒數(shù)),或者是一個(gè)從現(xiàn)在算起的以秒為單位的數(shù)字。對(duì)于后一種情況,這個(gè) 秒數(shù)不能超過60×60×24×30(30天時(shí)間的秒數(shù));如果失效的值大于這個(gè)值, 服務(wù)端會(huì)將其作為一個(gè)真實(shí)的Unix時(shí)間戳來處理而不是 自當(dāng)前時(shí)間的偏移。
如果失效值被設(shè)置為0(默認(rèn)),此元素永不過期(但是它可能由于服務(wù)端為了給其他新的元素分配空間而被刪除)。
三、回調(diào)1.結(jié)果回調(diào)Result callbacks方式在通過 Memcached::getDelayed()或Memcached::getDelayedBykey()方法獲取元素后,為結(jié)果集中每個(gè)元素調(diào)用一次。 回調(diào)函數(shù)可以接收到一個(gè)Memcached對(duì)象合一個(gè)數(shù)組描述的元素信息,此回調(diào)函數(shù)不需要返回任何信息。
Example #1 結(jié)果回調(diào)示例
<?php $m = new Memcached(); $m->addServer(’localhost’, 11211); $items = array(’key1’ => ’value1’,’key2’ => ’value2’,’key3’ => ’value3’ ); $m->setMulti($items); $m->getDelayed(array(’key1’, ’key3’), true, ’result_cb’); function result_cb($memc, $item) {var_dump($item); }?>
以上例程的輸出類似于:
array(3) { ['key']=> string(4) 'key1' ['value']=> string(6) 'value1' ['cas']=> float(49)}array(3) { ['key']=> string(4) 'key3' ['value']=> string(6) 'value3' ['cas']=> float(50)}2.通讀緩存回調(diào)
通讀緩存回調(diào)在一個(gè)元素沒有從服務(wù)端檢索到的時(shí)候被調(diào)用。這個(gè)回調(diào)函數(shù)會(huì)接收到Memcached對(duì)象,請(qǐng)求的key以及 一個(gè)引用方式傳遞的值變量等三個(gè)參數(shù)。此回調(diào)函數(shù)負(fù)責(zé)通過返回true或false來決定在key沒有值時(shí)設(shè)置一個(gè)默認(rèn)值。 如果回調(diào)返回true,Memcached會(huì)存儲(chǔ)'傳出參數(shù)'(引用傳遞的值變量)存儲(chǔ)的值到memcached服務(wù)端并將其返回到原來 的調(diào)用函數(shù)中。僅僅 Memcached::get()和 Memcached::getByKey() 支持這類回調(diào),因?yàn)镸emcache協(xié)議不支持在請(qǐng)求多個(gè)key時(shí)提供未檢索到key的信息。
Example #2 通讀回調(diào)示例
<?php $m = new Memcached(); $m->addServer(’localhost’, 11211); $profile_info = $m->get(’user:’.$user_id, ’user_info_cb’); function user_info_cb($memc, $key, &$value) {$user_id = substr($key, 5);/* 從數(shù)據(jù)庫讀取個(gè)人信息 *//* ... */$value = $profile_info;return true; }?>四、Sessions支持
memcached提供了一個(gè)自定義的session處理器可以被用于存儲(chǔ)用戶session數(shù)據(jù)到memcached服務(wù)端。 一個(gè)完全獨(dú)立的memcached實(shí)例將會(huì)在內(nèi)部使用,因此如果需要您可以設(shè)置一個(gè)不同的服務(wù)器池。session的 key被存儲(chǔ)在前綴memc.sess.key.之下,因此, 如果你對(duì)session和通常的緩存使用了 同樣的服務(wù)器池,請(qǐng)注意這一點(diǎn)。 譯注:另外一個(gè)session和通常緩存分離的原因是當(dāng)通常的緩存占滿了memcached服務(wù)端后,可能會(huì)導(dǎo)致你的session被 從緩存中踢除,導(dǎo)致用戶莫名的掉線。
session.save_handler 設(shè)置為memcached開啟memcached的session處理器。session.save_path定義一個(gè)逗號(hào)分隔的hostname:port樣式的session緩存服務(wù)器池,例如: 'sess1:11211, sess2:11211'.五、Memcached類表征到memcached服務(wù)集群的連接。
Memcached::add — 向一個(gè)新的key下面增加一個(gè)元素Memcached::addByKey — 在指定服務(wù)器上的一個(gè)新的key下增加一個(gè)元素Memcached::addServer — 向服務(wù)器池中增加一個(gè)服務(wù)器Memcached::addServers — 向服務(wù)器池中增加多臺(tái)服務(wù)器Memcached::append — 向已存在元素后追加數(shù)據(jù)Memcached::appendByKey — 向指定服務(wù)器上已存在元素后追加數(shù)據(jù)Memcached::cas — 比較并交換值Memcached::casByKey — 在指定服務(wù)器上比較并交換值Memcached::__construct — 創(chuàng)建一個(gè)Memcached實(shí)例Memcached::decrement — 減小數(shù)值元素的值Memcached::decrementByKey — Decrement numeric item’s value, stored on a specific serverMemcached::delete — 刪除一個(gè)元素Memcached::deleteByKey — 從指定的服務(wù)器刪除一個(gè)元素Memcached::deleteMulti — Delete multiple itemsMemcached::deleteMultiByKey — Delete multiple items from a specific serverMemcached::fetch — 抓取下一個(gè)結(jié)果Memcached::fetchAll — 抓取所有剩余的結(jié)果Memcached::flush — 作廢緩存中的所有元素Memcached::get — 檢索一個(gè)元素Memcached::getAllKeys — Gets the keys stored on all the serversMemcached::getByKey — 從特定的服務(wù)器檢索元素Memcached::getDelayed — 請(qǐng)求多個(gè)元素Memcached::getDelayedByKey — 從指定的服務(wù)器上請(qǐng)求多個(gè)元素Memcached::getMulti — 檢索多個(gè)元素Memcached::getMultiByKey — 從特定服務(wù)器檢索多個(gè)元素Memcached::getOption — 獲取Memcached的選項(xiàng)值Memcached::getResultCode — 返回最后一次操作的結(jié)果代碼Memcached::getResultMessage — 返回最后一次操作的結(jié)果描述消息Memcached::getServerByKey — 獲取一個(gè)key所映射的服務(wù)器信息Memcached::getServerList — 獲取服務(wù)器池中的服務(wù)器列表Memcached::getStats — 獲取服務(wù)器池的統(tǒng)計(jì)信息Memcached::getVersion — 獲取服務(wù)器池中所有服務(wù)器的版本信息Memcached::increment — 增加數(shù)值元素的值Memcached::incrementByKey — Increment numeric item’s value, stored on a specific serverMemcached::isPersistent — Check if a persitent connection to memcache is being usedMemcached::isPristine — Check if the instance was recently createdMemcached::prepend — 向一個(gè)已存在的元素前面追加數(shù)據(jù)Memcached::prependByKey — Prepend data to an existing item on a specific serverMemcached::quit — Close any open connectionsMemcached::replace — 替換已存在key下的元素Memcached::replaceByKey — Replace the item under an existing key on a specific serverMemcached::resetServerList — Clears all servers from the server listMemcached::set — 存儲(chǔ)一個(gè)元素Memcached::setByKey — Store an item on a specific serverMemcached::setMulti — 存儲(chǔ)多個(gè)元素Memcached::setMultiByKey — Store multiple items on a specific serverMemcached::setOption — 設(shè)置一個(gè)memcached選項(xiàng)Memcached::setOptions — Set Memcached optionsMemcached::setSaslAuthData — Set the credentials to use for authenticationMemcached::touch — Set a new expiration on an itemMemcached::touchByKey — Set a new expiration on an item on a specific server相關(guān)文章:
1. idea給項(xiàng)目打war包的方法步驟2. IntelliJ IDEA設(shè)置編碼格式的方法3. 使用 kind 和 Docker 啟動(dòng)本地的 Kubernetes環(huán)境4. Intellij IDEA 2020.3 配置教程詳解5. Python importlib模塊重載使用方法詳解6. 兩行Javascript代碼生成UUID的方法7. SpringBoot生成二維碼的實(shí)現(xiàn)8. 你真的需要Java 7嗎?9. IntelliJ IDEA刪除類的方法步驟10. ASP基礎(chǔ)入門第八篇(ASP內(nèi)建對(duì)象Application和Session)
