亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁技術文章
文章詳情頁

PHP高性能分布式內存對象緩存系統擴展Memcached的安裝及使用

瀏覽:97日期:2022-09-15 18:01:40
一、簡介及安裝

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,看到如下部分

PHP高性能分布式內存對象緩存系統擴展Memcached的安裝及使用

證明安裝成功。

二、超時時間

一些存儲命令在發送時會包含一個失效值(與一個元素或一個客戶端操作請求相關)到服務端。所有這類用法,實際發送的值可以 是一個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
標簽: PHP
相關文章:
主站蜘蛛池模板: 手机在线一区二区三区 | 特黄毛片 | 免费观看日本污污ww网站一区 | 国产美女一级特黄毛片 | www.91免费视频 | 国产精品v一区二区三区 | 国产制服丝袜在线观看 | 久久鸭综合久久国产 | 最刺激黄a大片免费观看下截 | 窝窝午夜看片成人精品 | 国产在线观看黄 | 亚洲高清国产品国语在线观看 | 国产亚洲免费观看 | 欧美性性性性性色大片免费的 | 免费观看色视频 | 亚洲精品一区二区深夜福利 | 久久久久国产一级毛片高清板 | 日韩毛片大全免费高清 | 在线看免费的污 | 窝窝午夜看片成人精品 | 欧美成人高清手机在线视频 | 99热在线观看精品 | 精品视频一区二区三区在线观看 | 久久国产视频一区 | 高清在线一区二区 | 亚洲一区中文字幕 | 国产精品日韩欧美一区二区 | 大片免费观看在线视频 | 三级全黄在线观看www桃花 | 日韩制服在线 | 亚洲一区综合在线播放 | 韩国黄色一级毛片 | 中文日韩| 爽爽影院色黄网站在线观看 | 狠狠做久久深爱婷婷97动漫 | 国产欧美日韩一区二区三区 | 精品欧美一区二区三区在线观看 | 四川丰满护士毛茸茸 | 欧美夜夜片a | 999国产一区二区三区四区 | 狠狠色丁香久久婷婷综合_中 |