PHP緩存技術:memcache函數詳解之一

Memcache函數庫是在PECL(PHP Extension Community Library)中,主要做用是搭建大容量的內存數據的臨時存放區域,在分佈式的時候做用體現的很是明 顯,網絡營銷培訓不然不建議使用。

Memcache::add -
 添加一個值,若是已經存在,則返回false
Memcache::addServer -
 添加一個可供使用的服務器地址
Memcache::close -
 關閉一個Memcache對象
Memcache::connect -
 建立一個Memcache對象
memcache_debug -
 控制調試功能! [4 F8 C2 e, X
Memcache::decrement -
 對保存的某個key中的值進行減法操做
Memcache::delete -
 刪除一個key值 
Memcache::flush -
 清除全部緩存的數據
Memcache::get -
 獲取一個key
Memcache::getExtendedStats -
 獲取進程池中全部進程的運行系通通計
Memcache::getServerStatus -
 獲取運行服務器的參數
Memcache::getStats -
 返回服務器的一些運行統計信息
Memcache::getVersion -
 返回運行的Memcache的版本信息
Memcache::increment -
 對保存的某個key中的值進行加法操做
Memcache::pconnect -
 建立一個Memcache的持久鏈接對象
Memcache::replace -
對一個已有的key進行覆寫操做
Memcache::set -
 添加一個值,若是已經存在,則覆寫
Memcache::setCompressThreshold -
 對大於某一大小的數據進行壓縮
Memcache::setServerParams -
 在運行時修改服務器的參數

Memcache::add

bool Memcache::add ( string $key , mixed $var [, int $flag [, int $expire ]] )
說 明:
若是$key不存在的時 候,使用這個函數來存儲$var的值。功能相同的函數是memcache_add()
參 數:
$key
 :將要存儲的鍵值。
$var
 :存儲的值,字符型和整型會按原值保存,其餘類型自動序列化之後保存。
$flag
:是否用MEMCACHE_COMPRESSED來壓縮存儲的值,true表示壓縮,false表示不壓縮。
$expire
:存 儲值的過時時間,若是爲表示不會過時,你能夠用unix時間戳或者描述來表示從如今開始的時間,可是你在使用秒數表示的時候,不要超過2592000秒 (表示30)
返回值: 
若是成功則返回 TRUE,失敗則返回 FALSE。若是$key值已經存在,則會返回FALSE。 其餘狀況下Memcache::add()的用法相似於Memcache::set()
例子:
web

$memcache_obj = memcache_connect(」localhost」, 11211);

memcache_add($memcache_obj, ’var_key’, ’test variable’, false, 30);

$memcache_obj->add(’var_key’, ’test variable’, false, 30);

Memcache::addServer

bool Memcache::addServer ( string $host [, int $port [, bool $persistent [, int$weight [, int $timeout [, int $retry_interval [, bool $status [, callback$failure_callback ]]]]]]] )
說 明: 
添加一個可供使用的服務器地址到鏈接池中,鏈接用Memcache::addServer打開,腳本執行完後自動關閉,或者能夠用 Memcache::close()手動關閉。相同函數是memcache_add_server()
當用這個方 法的時候(相對於Memcache::connect()Memcache::pconnect()方法),網絡鏈接只有等須要的時候纔會創建,所以不會由於增長很 多的服務器到鏈接池而增長系統負擔,由於不少服務器可能沒有使用。
故 障恢復會發生在這個方法執行的任何階段,只要其餘的服務器是正常的,這些鏈接請求的失敗用戶不會注意到。任何一種socket或者memcached服務 器級的錯誤能夠觸發故障恢復。正常的客戶端錯誤好比增長一個存在的鍵值不會引起故障恢復。
參數: 
$host
服務器的地址
$port
服務器端口
$persistent
是不是一個持久鏈接
$weight
 這臺服務器在全部服務器中所佔的權重
$timeout
鏈接的 持續時間
$retry_interval
鏈接重試的間隔時間,默認爲15,設置爲-1表示不進行重試
$status
控制服務器 的在線狀態
$failure_callback
容許設置 一個回掉函數來處理錯誤信息。
返 回值:* M0 L/ q9 ^2 O5 c* q/ J
若是成功則返回 TRUE,失敗則返回 FALSE
例子:
數組


$memcache = new Memcache;
$memcache->addServer(’memcache_host’, 11211);
$memcache->addServer(’memcache_host2′, 11211);

$memcache_obj = memcache_connect(’memcache_host’, 11211);
memcache_add_server($memcache_obj, ’memcache_host2′, 11211);

Memcache::close
bool Memcache::close ( void )
說明:
關閉 memcache服務器鏈接。這個函數不會關閉長鏈接,長鏈接只有在web服務器關閉或者重啓的時候纔會關閉。相同的函數 memcache_close()
返 回值:
若是成功則返回 TRUE,失敗則返回 FALSE
例 子: 

$memcache_obj = memcache_connect(’memcache_host’, 11211);

memcache_close($memcache_obj);


$memcache_obj = new Memcache;
$memcache_obj->connect(’memcache_host’, 11211);

$memcache_obj->close();

$memcache_obj = memcache_connect(’memcache_host’, 11211);

memcache_delete($memcache_obj, ’key_to_delete’, 10);

$memcache_obj = new Memcache;
$memcache_obj->connect(’memcache_host’, 11211);
$memcache_obj->delete(’key_to_delete’, 10);

Memcache::flush
bool Memcache::flush ( void ) 
說明: 
清除全部緩存的數 據。Memcache::flush實際上沒有釋放資源,它僅僅將全部的緩存標記爲過時,這樣可使新的緩存來覆蓋被佔的內存空間。同樣的函數是 memcache_flush()
返回值: 
若是成功則返回 TRUE,失敗則返回 FALSE
例子: 

$memcache_obj = memcache_connect(’memcache_host’, 11211);
memcache_flush($memcache_obj);

$memcache_obj = new Memcache;
$memcache_obj->connect(’memcache_host’, 11211);
$memcache_obj->flush();

Memcache::get
string Memcache::get ( string $key [, int &$flags ] )
array Memcache::get ( array $keys [, array &$flags ] )
說明:
方法的做用是獲取一個key值,key值能夠是一個數組,結果會包含鍵值對。
參數: 
$key
是鍵值或者一個鍵的數組值。
$flags
 若是這個參數存在,那麼$flags跟寫入這個參數的值相關,這些$flags 相似於Memcache::set()函數裏的$flags
返回值: 
若是成功,則返回key對應的值,若是失敗則返回false. 
例子:

$memcache_obj = memcache_connect(’memcache_host’, 11211);
$var = memcache_get($memcache_obj, ’some_key’);

$memcache_obj = new Memcache;
$memcache_obj->connect(’memcache_host’, 11211);
$var = $memcache_obj->get(’some_key’);
網絡營銷培訓(fblww-0215)緩存

相關文章
相關標籤/搜索