1、Memcache簡介php
Memcache是danga.com的一個項目,最先是爲LiveJournal服務的,目前全世界很多人使用這個緩存項目來構建本身大負載的網站,來分擔數據庫的壓力。它能夠對應任意多個連接,使用非阻塞的網絡IO。因爲它的工做機制是在內存中開闢一塊空間,而後創建一個HashTable,Memcached管理這些HashTable,因此速度很是快。linux
2、Memcache和Memcached的區別web
爲何會有Memcache和Memcached兩個名稱?其實Memcache是這個項目的名稱,而Memcached是他服務器端的主程序文件。一個是項目名稱,一個是主程序文件名。數據庫
3、Memcache的服務器端和客戶端安裝緩存
分爲兩個過程:Memcache服務器端的安裝和Memcached客戶端的安裝服務器
所謂服務器端的安裝就在在服務器(通常都是linux系統)上安裝Memcache實現數據的存儲。網絡
所謂客戶端的安裝就是指php去使用服務器端的Memcache提供的函數,須要php添加擴展。socket
4、PHP的Memcache客戶端全部方法總結tcp
memcache函數全部的方法列表以下:memcached
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 - 在運行時修改服務器的參數
5、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。