PHP環境下Memcache的使用方法


一、Memcache簡介

Memcache是danga.com的一個項目,最早是為LiveJournal服務的,目前全世界不少人使用這個緩存項目來構建自己大負載的網站,來分擔數據庫的壓力。它可以對應任意多個鏈接,使用非阻塞的網絡IO。由於它的工作機制是在內存中開辟一塊空間,然后建立一個HashTable,Memcached管理這些HashTable,所以速度非常快。

 

二、Memcache和Memcached的區別

為什么會有Memcache和Memcached兩個名稱?其實Memcache是這個項目的名稱,而Memcached是他服務器端的主程序文件。一個是項目名稱,一個是主程序文件名。

 

三、Memcache的服務器端和客戶端安裝

分為兩個過程:Memcache服務器端的安裝和Memcached客戶端的安裝

所謂服務器端的安裝就在在服務器(一般都是linux系統)上安裝Memcache實現數據的存儲。

所謂客戶端的安裝就是指php去使用服務器端的Memcache提供的函數,需要php添加擴展。

 

四、PHP的Memcache客戶端所有方法總結

memcache函數所有的方法列表如下:

Memcache::add - 添加一個值,如果已經存在,則返回false

Memcache::addServer - 添加一個可供使用的服務器地址

Memcache::close - 關閉一個Memcache對象

Memcache::connect - 創建一個Memcache對象

memcache_debug - 控制調試功能

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 - 在運行時修改服務器的參數

 

五、PHP的Memcache操作方法分解

 

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:存儲值得過期時間,如果0表示不會過期,你可以用unix時間戳或者描述來表示從現在開始時間,但是你在使用秒數表示的時候,不要超過2592000秒(表示30天)。

 

返回值:如果成功返回true,失敗則返回false。如果$key值已經存在,則會返回false,其他情況下Memcache::add()用法類似於Memcache::set()。

 

示例代碼:

<?php

//面向對象

$memcache = new Memcache;

$memcache->connect('127.0.0.1',11211);

$memcache->add('var_key','test variable',false,30);

echo $memcache->get('var_key').'<br>';

$memcache->close();

 

//面向過程

$memcache = memcache_connect('127.0.0.1',11211);

memcache_add($memcache,'var_key','test variable',false,30);

echo memcache_get($memcache,'var_key');

memcache_close($memcache);

?>

 

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::colse()手動關閉。相同的函數時memcache_add_server()。

 

當用這個方法的時候(相對於Memcache::connect()和Memcache::pconnect()方法),網絡連接只有等需要的時候才會連接,因此不會因為增加很多的服務器到連接池而增加系統負擔,因為很多服務器可能沒有使用。

故障恢復會發生在這個方法執行的任何階段,只要其他的服務器是正常的,這些連接請求的失敗用戶不會注意到。任何一種socket或者memcached服務器級的錯誤可以觸發故障恢復。正常的客戶端錯誤比如增加一個存在的鍵值不會引發故障恢復。

 

參數: 
$host服務器的地址 
$port服務器端口 
$persistent是否是一個持久連接 
$weight這台服務器在所有服務器中所占的權重 
$timeout連接的持續時間 
$retry_interval連接重試的間隔時間,默認為15,設置為-1表示不進行重試 
$status控制服務器的在線狀態 
$failure_callback允許設置一個回掉函數來處理錯誤信息。 

 

返回值: 
如果成功則返回 TRUE,失敗則返回 FALSE。

 

示例代碼:

<?php

//面向對象

$memcache = new Memcache;

$memcache->addServer('127.0.0.1',11211);

$memcache->addServer('182.92.233.100',11211);

//$memcache->flush();

var_dump($memcache->add('var_key','test variable1111',false,24*60*60));

echo $memcache->get('var_key');

$memcache->close();

 

//面向過程

$memcache = memcache_connect('10.0.3.73',11211);

memcache_add_server($memcache,'182.92.233.100',11211);

var_dump(memcache_get_extended_stats($memcache));

memcache_close($memcache);

?>

 

Memcache::close用法:

 

bool Memcache::close(viod);

 

說明:

關閉memcache服務器連接。這個函數不會關閉長連接,長連接只有在web服務器關閉或者重啟的時候才會關閉。相同函數memcache_close()。

 

返回值:

如果成功則返回true,失敗則返回false。

 

示例代碼:

<?php

//面向對象

$memcache = new Memcache;

$memcache->connect('127.0.0.1',11211);

if($memcache->close()){

      echo '已斷開與服務器的鏈接<br>';

}

//面向過程

$memcache = memcache_connect('127.0.0.1',11211);

if(memcache_close($memcache)){

      echo '已斷開與服務器的鏈接<br>';

}

?>

 

Memcache::connect用法

 

bool Memcache::connect(string $host[,int $port[,int $timeout]]);

 

說明:

打開memcached服務器連接,建立一個到memcached服務器的連接,用Memcache::connect打開的連接會在腳本執行完畢后自動關閉。你也可以用Memcache::close()去關閉連接。相同的函數時memcache_close()。

 

參數:

$host:指向memcached正在收聽的連接主機。

$port:指向memcached正在收聽的連接端口。

$timeout:用於連接守護進程的秒數,當你改變默認1秒的值時,你需要考慮一下,如果你的連接太慢的話,你可能會失去緩存的優勢。

 

返回值:

如果成功則返回true,失敗則返回false。

 

示例代碼:

<?php

//面向對象

$memcache = new Memcache;

$memcache->connect('127.0.0.1',11211);

$memcache->close();

 

//面向過程

$memcache = memcache_connect('127.0.0.1',11211);

memcache_close($memcache);

 

?>

 

Memcache::debug用法:

 

bool  memcache_debug(bool $on_off);

 

說明:

控制調試功能,前提是php在編譯的時候使用了-enable_debug選項,否則這個函數不會有作用。

 

參數:

$on_off:true表示開啟調試,false表示關閉調試

 

返回值:

如果php在編譯的時候使用了-enable-debug選項,返回true,否則返回false。

 

Memcache::decrement方法:

 

Int Memcache::decrement(string $key[,int value]);

 

說明

Memcache::decrement方法的作用是對保存的某個key的值進行減法操作,用法跟Memcache::increment類似。

 

參數

Key: 想要減少的鍵的名字

Value:想要減少的值

 

返回值:

如果成功,返回被減少后的值,如果失敗返回false

 

示例代碼:

<?php

//面向對象

$memcache = new Memcache;

$memcache->connect('127.0.0.1',11211);

$memcache->flush();

$memcache->set('var_key',8,false,24*60*60);

echo $memcache->get('var_key').'<br>';

echo $memcache->increment('var_key',4).'<br>';

echo $memcache->decrement('var_key',5).'<br>';

$memcache->close();

//面向過程

$memcache = memcache_connect('127.0.0.1',11211);

memcache_flush($memcache);

memcache_set($memcache,'var_key',8,false,24*60*60);

echo memcache_get($memcache,'var_key').'<br>';

echo memcache_increment($memcache,'var_key',4).'<br>';

echo memcache_decrement($memcache,'var_key',5).'<br>';

memcache_close($memcache);

?>

 

Memcache::delete用法

 

bool Memcache::delete(string $key[,int timeout]);

 

說明

刪除一個key值,如果參數timeout被設置,那么存儲的值會在設置的秒數以后過期,你也可以用函數memcache_delete()。

 

返回值

如果成功則返回true,失敗則返回false。

 

示例代碼

<?php

//面向對象

$memcache = new Memcache;

$memcache->connect('127.0.0.1',11211);

$memcache->flush();

$memcache->set('var_key',8,false,24*60*60);

echo $memcache->get('var_key').'<br>';

$memcache->delete('var_key',0);

echo $memcache->get('var_key').'<br>';

$memcache->close();

//面向過程

$memcache = memcache_connect('127.0.0.1',11211);

memcache_flush($memcache);

memcache_set($memcache,'var_key',8,false,24*60*60);

echo memcache_get($memcache,'var_key').'<br>';

memcache_delete($memcache,'var_key',0);

echo memcache_get($memcache,'var_key').'<br>';

memcache_close($memcache);

 

?>

系統提示:

PHP Notice:  Memcache::delete(): Server 192.168.10.131 (tcp 11211) failed with: CLIENT_ERROR bad command line format.  Usage: delete <key> [noreply]

 

memcache服務端版本>=1.4.3的delete方法與之前的版本有調整,因此有這個問題。最好解決是把linux下的memcache服務端版本改為1.4.2版本的。

 

 

Memcache::flush方法

 

bool Memcache::flush(viod);

 

說明

清除所有緩存數據。Memcache::flush實際上沒有釋放資源,它僅僅將所有的緩存標記為過期,這樣可以使新的緩存覆蓋被占用的內存空間。相同函數memcache_flush()。

 

返回值

如果成功則返回true,失敗則返回false。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM