使用PHP創建Memcached數據庫客戶端
Memcached 是一個鍵值存儲系統,它將關鍵數據存儲在內存中,大大減少存取數據的時間。使用Memcached的好處不言而喻,它不僅減少了系統訪問數據庫的壓力,而且提高系統的反應速度。至于什么樣的系統需要使用memcache,筆者建議數據量大,訪問頻繁系統可以采取Memcached作為緩存的中間層。
使用Memcached的缺點除了增加程序的代碼量,還有就是不能保證數據庫的實時性,另外在第一次初始化數據庫會需要額外的時間。但是這些的缺點比起它的優點是很微不足道。
PHP帶有操作Memcached的擴展,它提供一組函數來操作Memcached服務器,將他們簡單分一下類:
1。Memcached的連接函數(connect, pconnect)
2。memcahced的操作函數(set, get, delete, replace, flush)
3。多服務器配置函數(addServer)
4。狀態監控函數(getStats.....)
下面摘一段代碼,給大家一個直觀的印象:(假設Memcached安裝在172.10.10.10上面,端口號12121)
- $memcache = new Memcached();
- $memcahce->connect('172.10.10.10', 12121);
- $memcache->set('Key', 'Value');
- $memcache->get('Key');
上面的主要完成了Memcached的簡單操作流程:連接Memcached服務器,設置值,取值('Key'的值是'Value');
這里需要向大家說明一下addServer函數和connect函數,addServer是將多個服務器放在連接池,而connect只是將連接某一臺服務器;如果在使用了addServer,再使用connect,這里就會只使用一臺服務器。
介紹了Memcached的使用后,下面向大家介紹如何編寫自己的PHP Memcached的客戶端。
Memcached是一個服務器端程序,我們自然可以使用PHP中的套接字程序來連接,并進行相應的通訊,完成數據的存儲操作。要使用PHP和Memcached通訊,首先需要知道Memcached的通訊協議,相關的信息可以在Memcached的源碼的doc/protocol.txt中找到。
這里筆者使用get命令向大家展示一下這個過程
這個命令主要是從數據中提取數據,輸入格式: get key\r\n
如果服務器沒有這個值,則返回: END\r\n
如果這個值存在,返回: VALUE key <標記> <數據長度> \r\n 數據塊\r\n
以下代碼是簡單模擬的客戶端操作
- $fp = fsocketopen('172.10.10.10', 12121, $errorno, $errstr, 1);
- if(!$fp)
- echo "$errstr";
- else
- {
- $out = "get key \r\n";
- fwrite($out);
- while(!feof($fp))
- $str . = fgets($fp);
- if(stripos($str, 'END') ===0)
- exit("NO value find")
- $arr = implode('\r\n', $str);
- echo $arr[1];
- }
簡單解釋上面的代碼,使用fsocketopen打開服務器的socket通訊接口,然后向其發送get key命令, 然后獲取返回的數據,并解析返回的數據。這里都沒有做異常的處理,在編程的時候要填上。
延伸閱讀
Memcached 是一個高性能的分布式內存對象緩存系統,用于動態Web應用以減輕數據庫負載。它通過在內存中緩存數據和對象來減少讀取數據庫的次數,從而提供動態、數據庫驅動網站的速度。Memcached基于一個存儲鍵/值對的hashmap。其守護進程(daemon )是用C寫的,但是客戶端可以用任何語言來編寫,并通過memcached協議與守護進程通信。但是它并不提供冗余(例如,復制其hashmap條目);當某個服務器S停止運行或崩潰了,所有存放在S上的鍵/值對都將丟失。
Memcached由Danga Interactive開發,用于提升LiveJournal.com訪問速度的。LJ每秒動態頁面訪問量幾千次,用戶700萬。Memcached將數據庫負載大幅度降低,更好的分配資源,更快速訪問。
原文標題:使用php操作memcached
鏈接:http://www.cnblogs.com/kucongzhi/archive/2010/07/11/1775275.html
【編輯推薦】