麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 開發 > PHP > 正文

PHP環境中Memcache的安裝和使用

2024-05-04 23:40:10
字體:
來源:轉載
供稿:網友

本文給大家介紹php環境中memcache的安裝和使用,它可以應用任意多個連接,使用非阻塞的網絡IO。由于它的工作機制是在內存中開辟一塊空間,然后建立一個HashTable,Memcached自管理這些HashTable,感興趣的朋友一起學習吧

Memcache是danga.com的一個項目,最早是為 LiveJournal 服務的,目前全世界不少人使用這個緩存項目來構建自己大負載的網站,來分擔數據庫的壓力。它可以應對任意多個連接,使用非阻塞的網絡IO。由于它的工作機制是在內存中開辟一塊空間,然后建立一個HashTable,Memcached自管理這些HashTable。Memcache官方網站:http://www.danga.com/memcached,更多詳細的信息可以來這里了解。

為什么會有Memcache和memcached兩種名稱?其實Memcache是這個項目的名稱,而memcached是它服務器端的主程序文件名,知道我的意思了把~~~~。一個是項目名稱,一個是主程序文件名,在網上看到了很多人不明白,于是混用了。

Memcache的安裝

分為兩個過程:memcache服務器端的安裝和memcached客戶端的安裝。

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

所謂客戶端的安裝就是指php(或者其他程序,Memcache還有其他不錯的api接口提供)去使用服務器端的Memcache提供的函數,需要php添加擴展。

PHP的Memcache

 

 
  1. <?php 
  2. //連接 
  3. $mem = new Memcache; 
  4. $mem->connect("db.nowamagic.net", ); 
  5. //保存數據 
  6. $mem->set('key''This is first value', , ); 
  7. $val = $mem->get('key'); 
  8. echo "Get key value: " . $val ."<br />"
  9. //替換數據 
  10. $mem->replace('key''This is replace value', , ); 
  11. $val = $mem->get('key'); 
  12. echo "Get key value: " . $val . "<br />"
  13. //保存數組 
  14. $arr = array('aaa''bbb''ccc''ddd'); 
  15. $mem->set('key', $arr, , ); 
  16. $val = $mem->get('key'); 
  17. echo "Get key value: "
  18. print_r($val); 
  19. echo "<br />"
  20. //刪除數據 
  21. $mem->delete('key'); 
  22. $val = $mem->get('key'); 
  23. echo "Get key value: " . $val . "<br />"
  24. //清除所有數據 
  25. $mem->flush(); 
  26. $val = $mem->get('key'); 
  27. echo "Get key value: "
  28. print_r($val); 
  29. echo "<br />"
  30. //關閉連接 
  31. $mem->close(); 
  32. ?> 

如果正常的話,瀏覽器將輸出:

Get key value: This is first value

Get key value: This is replace value

Get key value: Array ( [] => aaa [] => bbb [] => ccc [] => ddd )

Get key value:

Get key value:

程序代碼分析

初始化一個Memcache的對象:$mem = new Memcache;

連接到我們的Memcache服務器端,第一個參數是服務器的IP地址,也可以是主機名,第二個參數是Memcache的開放的端口:$mem->connect("192.168.0.200", 12000);

保存一個數據到Memcache服務器上,第一個參數是數據的key,用來定位一個數據,第二個參數是需要保存的數據內容,這里是一個字符串,第三個參數是一個標記,一般設置為0或者MEMCACHE_COMPRESSED就行了,第四個參數是數據的有效期,就是說數據在這個時間內是有效的,如果過去這個時間,那么會被Memcache服務器端清除掉這個數據,單位是秒,如果設置為0,則是永遠有效,我們這里設置了60,就是一分鐘有效時間:$mem->set(‘key1‘, ‘This is first value', 0, 60);

從Memcache服務器端獲取一條數據,它只有一個參數,就是需要獲取數據的key,我們這里是上一步設置的key1,現在獲取這個數據后輸出輸出:

 

 
  1. $val = $mem->get('key′); 
  2. echo "Get key value: " . $val; 

現在是使用replace方法來替換掉上面key1的值,replace方法的參數跟set是一樣的,不過第一個參數key1是必須是要替換數據內容的key,最后輸出了:

 

 
  1. $mem->replace('key''This is replace value', , ); 
  2. $val = $mem->get('key'); 
  3. echo "Get key value: " . $val; 

同樣的,Memcache也是可以保存數組的,下面是在Memcache上面保存了一個數組,然后獲取回來并輸出:

 

 
  1. $arr = array('aaa''bbb''ccc''ddd'); 
  2. $mem->set('key', $arr, , ); 
  3. $val = $mem->get('key'); 
  4. print_r($val); 

現在刪除一個數據,使用delte接口,參數就是一個key,然后就能夠把Memcache服務器這個key的數據刪除,最后輸出的時候沒有結果:

 

 
  1. $mem->delete('key'); 
  2. $val = $mem->get('key'); 
  3. echo "Get key value: " . $val . "<br />"

最后我們把所有的保存在Memcache服務器上的數據都清除,會發現數據都沒有了,最后輸出key2的數據為空,最后關閉連接:

 

 
  1. $mem->flush(); 
  2. $val = $mem->get('key'); 
  3. echo "Get key value: "
  4. print_r($val); 
  5. echo "<br />"

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 ... –dport -j ACCEPT

# iptables -A INPUT -p udp -s ... –dport -j ACCEPT

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


注:相關教程知識閱讀請移步到PHP教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: xxxxhd73国产 | 毛片在线播放视频 | 国产一区二区免费在线观看 | 久久久久久久久浪潮精品 | 色999久久久精品人人澡69 | 亚洲午夜在线视频 | 国产精品999在线观看 | 亚洲骚妻 | 国产精品久久久久久久四虎电影 | 91精品一区二区综合在线 | 国产精品刺激对白麻豆99 | 成熟女人特级毛片www免费 | 色播视频在线播放 | 综合在线视频 | 成人偷拍片视频在线观看 | 久久国产亚洲精品 | 亚洲小视频在线 | 福利在线小视频 | 国产1区在线观看 | 爱视频福利 | 国产在线观看免费视频软件 | 久久久www成人免费毛片 | 热99在线视频 | 亚洲成人综合网站 | 九一传媒在线观看 | 免费一级毛片在线播放不收费 | 国产精品视频一区二区三区综合 | 国产精品成人亚洲一区二区 | 成人免费在线视频播放 | 成人毛片网站 | 久久久成人免费视频 | 一区国产视频 | 成人午夜免费观看 | 亚洲最大的成人网 | 欧美激情性色生活片在线观看 | 国产精品v片在线观看不卡 成人一区二区三区在线 | 香蕉久久久久久 | 亚洲成人福利电影 | 国产色91 | 亚洲第一页综合 | av在线免费观看播放 |