PHP高性能分布式內存對象緩存系統擴展Memcached的安裝及使用
memcached是一個高性能分布式的內存對象緩存系統, 通常被用于降低數據庫加載壓力以提高動態web應用的響應速度。
此擴展使用了libmemcached庫提供的api與memcached服務端進行交互。它還提供了一個session處理器(memcached)。
關于memcached的安裝,可參考這篇文章:Ubuntu中memcached的安裝和配置。
在安裝php擴展memcached之前,需要先安裝libmemcached,libmemcached是memcached的C/C++本地客戶端庫。
安裝libmemcached之前,還要先安裝libcloog-ppl0,否則編譯安裝過程中會出錯:
sudo apt-get install libcloog-ppl0
然后從這里http://libmemcached.org/libMemcached.html下載所需的libmemcached源碼安裝包,解壓到指定目錄,進入該目錄,然后執行以下指令:
./configure --prefix=/usr/local/libmemcachedmakesudo make install
然后就可以進行php的memcached擴展的安裝了,從這里下載所需的源碼安裝包:http://pecl.php.net/package/memcached,解壓到指定目錄,進入該目錄,然后執行以下指令:
phpize./configure --with-php-config=/usr/local/php/bin/php-config --with-libmemcached-dir=/usr/local/libmemcachedmakesudo make install
在安裝過程中可能會報錯:
未知類型名稱:memcached_server_instance_st
而導致make失敗,解決辦法如下:
在memcached擴展解壓目錄下找到這個文件:php_libmemcached_compat.h,然后在其中添加下面這行
typedef const struct memcached_server_st *memcached_server_instance_st;
再次make,就OK了。
安裝成功后,在php.ini中添加extension=memcacached,然后重啟apache,查看phpinfo,看到如下部分
證明安裝成功。
二、超時時間一些存儲命令在發送時會包含一個失效值(與一個元素或一個客戶端操作請求相關)到服務端。所有這類用法,實際發送的值可以 是一個Unix時間戳(自1970年1月1日起至失效時間的整型秒數),或者是一個從現在算起的以秒為單位的數字。對于后一種情況,這個 秒數不能超過60×60×24×30(30天時間的秒數);如果失效的值大于這個值, 服務端會將其作為一個真實的Unix時間戳來處理而不是 自當前時間的偏移。
如果失效值被設置為0(默認),此元素永不過期(但是它可能由于服務端為了給其他新的元素分配空間而被刪除)。
三、回調1.結果回調Result callbacks方式在通過 Memcached::getDelayed()或Memcached::getDelayedBykey()方法獲取元素后,為結果集中每個元素調用一次。 回調函數可以接收到一個Memcached對象合一個數組描述的元素信息,此回調函數不需要返回任何信息。
Example #1 結果回調示例
<?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.通讀緩存回調
通讀緩存回調在一個元素沒有從服務端檢索到的時候被調用。這個回調函數會接收到Memcached對象,請求的key以及 一個引用方式傳遞的值變量等三個參數。此回調函數負責通過返回true或false來決定在key沒有值時設置一個默認值。 如果回調返回true,Memcached會存儲'傳出參數'(引用傳遞的值變量)存儲的值到memcached服務端并將其返回到原來 的調用函數中。僅僅 Memcached::get()和 Memcached::getByKey() 支持這類回調,因為Memcache協議不支持在請求多個key時提供未檢索到key的信息。
Example #2 通讀回調示例
<?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);/* 從數據庫讀取個人信息 *//* ... */$value = $profile_info;return true; }?>四、Sessions支持
memcached提供了一個自定義的session處理器可以被用于存儲用戶session數據到memcached服務端。 一個完全獨立的memcached實例將會在內部使用,因此如果需要您可以設置一個不同的服務器池。session的 key被存儲在前綴memc.sess.key.之下,因此, 如果你對session和通常的緩存使用了 同樣的服務器池,請注意這一點。 譯注:另外一個session和通常緩存分離的原因是當通常的緩存占滿了memcached服務端后,可能會導致你的session被 從緩存中踢除,導致用戶莫名的掉線。
session.save_handler 設置為memcached開啟memcached的session處理器。session.save_path定義一個逗號分隔的hostname:port樣式的session緩存服務器池,例如: 'sess1:11211, sess2:11211'.五、Memcached類表征到memcached服務集群的連接。
Memcached::add — 向一個新的key下面增加一個元素Memcached::addByKey — 在指定服務器上的一個新的key下增加一個元素Memcached::addServer — 向服務器池中增加一個服務器Memcached::addServers — 向服務器池中增加多臺服務器Memcached::append — 向已存在元素后追加數據Memcached::appendByKey — 向指定服務器上已存在元素后追加數據Memcached::cas — 比較并交換值Memcached::casByKey — 在指定服務器上比較并交換值Memcached::__construct — 創建一個Memcached實例Memcached::decrement — 減小數值元素的值Memcached::decrementByKey — Decrement numeric item’s value, stored on a specific serverMemcached::delete — 刪除一個元素Memcached::deleteByKey — 從指定的服務器刪除一個元素Memcached::deleteMulti — Delete multiple itemsMemcached::deleteMultiByKey — Delete multiple items from a specific serverMemcached::fetch — 抓取下一個結果Memcached::fetchAll — 抓取所有剩余的結果Memcached::flush — 作廢緩存中的所有元素Memcached::get — 檢索一個元素Memcached::getAllKeys — Gets the keys stored on all the serversMemcached::getByKey — 從特定的服務器檢索元素Memcached::getDelayed — 請求多個元素Memcached::getDelayedByKey — 從指定的服務器上請求多個元素Memcached::getMulti — 檢索多個元素Memcached::getMultiByKey — 從特定服務器檢索多個元素Memcached::getOption — 獲取Memcached的選項值Memcached::getResultCode — 返回最后一次操作的結果代碼Memcached::getResultMessage — 返回最后一次操作的結果描述消息Memcached::getServerByKey — 獲取一個key所映射的服務器信息Memcached::getServerList — 獲取服務器池中的服務器列表Memcached::getStats — 獲取服務器池的統計信息Memcached::getVersion — 獲取服務器池中所有服務器的版本信息Memcached::increment — 增加數值元素的值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 — 向一個已存在的元素前面追加數據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 — 存儲一個元素Memcached::setByKey — Store an item on a specific serverMemcached::setMulti — 存儲多個元素Memcached::setMultiByKey — Store multiple items on a specific serverMemcached::setOption — 設置一個memcached選項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相關文章:
1. 詳解springBoot啟動時找不到或無法加載主類解決辦法2. SpringBoot+SpringCache實現兩級緩存(Redis+Caffeine)3. springboot集成與使用Sentinel的方法4. 詳解php如何合并身份證正反面圖片為一張圖片5. Java基于redis和mysql實現簡單的秒殺(附demo)6. Spring @Primary和@Qualifier注解原理解析7. java使用FFmpeg合成視頻和音頻并獲取視頻中的音頻等操作(實例代碼詳解)8. php設計模式之模板模式實例分析【星際爭霸游戲案例】9. ASP.NET MVC視圖頁使用jQuery傳遞異步數據的幾種方式詳解10. AJAX實現省市縣三級聯動效果
