這篇文章主要介紹了PHP中的Memcache,從Memcache簡介開始,詳細講解了如Memcache和memcached的區別、PHP的Memcache所有操作方法、每個操作方法的詳細解釋等,需要的朋友可以參考下
一、Memcache簡介 Memcache是danga.com的一個項目,最早是為 LiveJournal 服務的,目前全世界不少人使用這個緩存項目來構建自己大負載的網站,來分擔數據庫的壓力。它可以應對任意多個連接,使用非阻塞的網絡IO。由於它的工作機制是在內存中開辟一塊空間,然後建立一個HashTable,Memcached管理這些HashTable,所以速度非常快。 二、Memcache和memcached的區別 為什麼會有Memcache和memcached兩種名稱?其實Memcache是這個項目的名稱,而memcached是它服務器端的主程序文件名,知道我的意思了把~~~~。一個是項目名稱,一個是主程序文件名,在網上看到了很多人不明白,於是混用了。 三、Memcache的服務器端和客戶端安裝 分為兩個過程:memcache服務器端的安裝和memcached客戶端的安裝。 所謂服務器端的安裝就是在服務器(一般都是linux系統)上安裝Memcache實現數據的存儲。 所謂客戶端的安裝就是指php(或者其他程序,Memcache還有其他不錯的api接口提供)去使用服務器端的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_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允許設置一個回掉函數來處理錯誤信息。 返回值: 如果成功則返回 TRUE,失敗則返回 FALSE。 例子: 代碼如下:<?php $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。 例子: 代碼如下: <?php $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::connect用法 代碼如下:bool Memcache::connect ( string $host [, int $port [, int $timeout ]] ) 說明: 打開memcached服務器連接,建立一個到memcached服務器的連接,用Memcache::connect打開的連接會在腳本執行完畢後自動關閉。你也可以用Memcache::close()去關閉連接。相同的函數是memcache_connect()。 參數: $host:指向memcached正在收聽的鏈接的主機,這個參數會有另一種特殊的連接方式unix:///path/to/memcached.sock,即用unix的域名sockets,這種情況下,端口必須設置為0 $port:指向memcached正在收聽的鏈接的端口,用unix的域名sockets的情況下,端口必須設置為0 $timeout:用於連接守護進程的秒數,當你改變默認的1秒的值的時候,你需要考慮一下,如果你的連接太慢的話,你可能會失去緩存的優勢。 返回值: 如果成功則返回 TRUE,失敗則返回 FALSE。 例子: 代碼如下: <?php $memcache_obj = memcache_connect('memcache_host', 11211); $memcache = new Memcache; $memcache->connect('memcache_host', 11211); ?> 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::decremen方法的作用是對保存的某個key中的值進行減法操作,用法跟Memcache::increment類似。 你也可以用memcache_decrement()函數。 參數: Key:想要減少的鍵的名字 Value:想要減少的值。 返回值: 如果成功,返回被減少後的值,如果失敗返回false。 例子: 代碼如下: <?php $memcache = new Memcache; $memcache->connect('localhost', 11211); $memcache->set('test_item', 8); $memcache->increment('test_item', 4); echo $memcache->decrement('test_item', 7); // 顯示 5 ?> 這個例子連Memcache::increment函數都一塊演示了。 Memcache::delete用法