PHP操作Memcache基本函數


Memcache模塊提供了於Memcached方便的面向過程及面向對象的接口,Memcached是為了降低動態web應用從數據庫加載數據而產生的一種常駐進程緩存產品。Memcache模塊同時提供了一個session 處理器 (memcache)。下面PHP程序員雷雪松詳細的講解下PHP操作Memcache基本函數。

Memcache — Memcache類
Memcache::add — 增加一個條目到緩存服務器
Memcache::addServer — 向連接池中添加一個memcache服務器
Memcache::close — 關閉memcache連接
Memcache::connect — 打開一個memcached服務端連接
Memcache::decrement — 減小key的值
Memcache::delete — 從服務端刪除一個key
Memcache::flush — 清洗(刪除)已經存儲的所有的key
Memcache::get — 從服務端檢回一個key
Memcache::getExtendedStats — 緩存服務器池中所有服務器統計信息
Memcache::getServerStatus — 用於獲取一個服務器的在線/離線狀態
Memcache::getStats — 獲取服務器統計信息
Memcache::getVersion — 返回服務器版本信息
Memcache::increment — 增加一個key的值
Memcache::pconnect — 打開一個到服務器的持久化連接
Memcache::replace — 替換已經存在的key的值
Memcache::set — 儲存值,沒有會新增一個key,已經存在的key直接替換
Memcache::setCompressThreshold — 開啟大值自動壓縮
Memcache::setServerParams — 運行時修改服務器參數和狀態

Memcache 函數
memcache_debug — 轉換調試輸出的開/關

Memcache模塊同時提供了一個session 處理器 :php使用memcache來存儲session

 

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用法

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

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

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

例子: 

<?php 

$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。

例子:

<?php 

$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.
例子: 

<?php 

$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'); 

$memcache_obj = memcache_connect('memcache_host', 11211); 
$var = memcache_get($memcache_obj, Array('some_key', 'another_key')); 

$memcache_obj = new Memcache; 
$memcache_obj->connect('memcache_host', 11211); 
$var = $memcache_obj->get(Array('some_key', 'second_key')); 

?> 

  Memcache::set

bool Memcache::set ( string $key , mixed $var [, int $flag [, int $expire ]] )

  說明:
添加一個值,如果已經存在,則覆寫。相同函數是memcache_set()

參數:
$key :將要存儲的鍵值。
$var :存儲的值,字符型和整型會按原值保存,其他類型自動序列化以后保存。
$flag:是否用MEMCACHE_COMPRESSED來壓縮存儲的值,true表示壓縮,false表示不壓縮。
$expire:存儲值的過期時間,如果為0表示不會過期,你可以用unix時間戳或者描述來表示從現在開始的時間,但是你在使用秒數表示的時候,不要超過2592000秒 (表示30天)。

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

例子: 

$memcache_obj = new Memcache; 
$memcache_obj->connect('memcache_host', 11211); 
$memcache_obj->set('var_key', 'some really big variable', MEMCACHE_COMPRESSED, 50); 
echo $memcache_obj->get('var_key'); 

  Memcache::getVersion

string Memcache::getVersion ( void )

  說明:
返回運行的Memcache的版本信息。相同函數memcache_get_version()

返回值:
成功返回服務器的版本信息,失敗的時候返回false。

例子

<?php 
$memcache = new Memcache; 
$memcache->connect('memcache_host', 11211); 
echo $memcache->getVersion(); 

$memcache = memcache_connect('memcache_host', 11211); 
echo memcache_get_version($memcache); 
?> 

  Memcache::increment 

int Memcache::increment ( string $key [, int $value ] )

  對保存的某個key中的值進行加法操作
用法參考Memcache::decrement
Memcache::replace

bool Memcache::replace ( string $key , mixed $var [, int $flag [, int $expire ]] )

  說明:
對一個已有的key進行覆寫操作。相同函數是memcache_replace()

參數:
$key :將要存儲的鍵值。
$var :存儲的值,字符型和整型會按原值保存,其他類型自動序列化以后保存。
$flag:是否用MEMCACHE_COMPRESSED來壓縮存儲的值,true表示壓縮,false表示不壓縮。
$expire:存儲值的過期時間,如果為0表示不會過期,你可以用unix時間戳或者描述來表示從現在開始的時間,但是你在使用秒數表示的時候,不要超過2592000秒 (表示30天)。

返回值:
如果成功則返回 TRUE,失敗則返回 FALSE。如果$key值已經存在,則會返回FALSE。 

<?php 

$memcache_obj = memcache_connect('memcache_host', 11211); 
memcache_replace($memcache_obj, "test_key", "some variable", false, 30); 
$memcache_obj->replace("test_key", "some variable", false, 30); 

?> 

  八、什么時候使用Memcache和Memcache的使用環境

使用Memcache的網站一般流量都是比較大的,為了緩解數據庫的壓力,讓Memcache作為一個緩存區域,把部分信息保存在內存中,在前端能夠迅速的進行存取。那么一般的焦點就是集中在如何分擔數據庫壓力和進行分布式,畢竟單台Memcache的內存容量的有限的。我這里簡單提出我的個人看法,未經實踐,權當參考。

分布式應用

Memcache本來支持分布式,我們客戶端稍加改造,更好的支持。我們的key可以適當進行有規律的封裝,比如以user為主的網站來說,每個用戶都有User ID,那么可以按照固定的ID來進行提取和存取,比如1開頭的用戶保存在第一台Memcache服務器上,以2開頭的用戶的數據保存在第二胎Mecache服務器上,存取數據都先按照User ID來進行相應的轉換和存取。
但是這個有缺點,就是需要對User ID進行判斷,如果業務不一致,或者其他類型的應用,可能不是那么合適,那么可以根據自己的實際業務來進行考慮,或者去想更合適的方法。

減少數據庫壓力

這個算是比較重要的,所有的數據基本上都是保存在數據庫當中的,每次頻繁的存取數據庫,導致數據庫性能極具下降,無法同時服務更多的用戶,比如MySQL,特別頻繁的鎖表,那么讓Memcache來分擔數據庫的壓力吧。我們需要一種改動比較小,並且能夠不會大規模改變前端的方式來進行改變目前的架構。
我考慮的一種簡單方法:
后端的數據庫操作模塊,把所有的Select操作提取出來(update/delete/insert不管),然后把對應的SQL進行相應的hash算法計算得出一個hash數據key(比如MD5或者SHA),然后把這個key去Memcache中查找數據,如果這個數據不存在,說明還沒寫入到緩存中,那么從數據庫把數據提取出來,一個是數組類格式,然后把數據在set到Memcache中,key就是這個SQL的hash值,然后相應的設置一個失效時間,比如一個小時,那么一個小時中的數據都是從緩存中提取的,有效減少數據庫的壓力。缺點是數據不實時,當數據做了修改以后,無法實時到前端顯示,並且還有可能對內存占用比較大,畢竟每次select出來的數據數量可能比較巨大,這個是需要考慮的因素。

九、Memcache的安全

我們上面的Memcache服務器端都是直接通過客戶端連接后直接操作,沒有任何的驗證過程,這樣如果服務器是直接暴露在互聯網上的話是比較危險,輕則數據泄露被其他無關人員查看,重則服務器被入侵,因為Mecache是以root權限運行的,況且里面可能存在一些我們未知的bug或者是緩沖區溢出的情況,這些都是我們未知的,所以危險性是可以預見的。為了安全起見,我做兩點建議,能夠稍微的防止黑客的入侵或者數據的泄露。

內網訪問

最好把兩台服務器之間的訪問是內網形態的,一般是Web服務器跟Memcache服務器之間。普遍的服務器都是有兩塊網卡,一塊指向互聯網,一塊指向內網,那么就讓Web服務器通過內網的網卡來訪問Memcache服務器,我們Memcache的服務器上啟動的時候就監聽內網的IP地址和端口,內網間的訪問能夠有效阻止其他非法的訪問。

復制代碼 代碼如下:
# memcached -d -m 1024 -u root -l 192.168.0.200 -p 11211 -c 1024 -P /tmp/memcached.pid


Memcache服務器端設置監聽通過內網的192.168.0.200的ip的11211端口,占用1024MB內存,並且允許最大1024個並發連接。

設置防火牆
防火牆是簡單有效的方式,如果卻是兩台服務器都是掛在網的,並且需要通過外網IP來訪問Memcache的話,那么可以考慮使用防火牆或者代理程序來過濾非法訪問。一般我們在Linux下可以使用iptables或者FreeBSD下的ipfw來指定一些規則防止一些非法的訪問,比如我們可以設置只允許我們的Web服務器來訪問我們Memcache服務器,同時阻止其他的訪問。

復制代碼 代碼如下:
# iptables -F
# iptables -P INPUT DROP
# iptables -A INPUT -p tcp -s 192.168.0.2 –dport 11211 -j ACCEPT
# iptables -A INPUT -p udp -s 192.168.0.2 –dport 11211 -j ACCEPT


上面的iptables規則就是只允許192.168.0.2這台Web服務器對Memcache服務器的訪問,能夠有效的阻止一些非法訪問,相應的也可以增加一些其他的規則來加強安全性,這個可以根據自己的需要來做。 


免責聲明!

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



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