你好,是我琉憶。
繼上週(2019.2-11至2-15)發佈的「PHP面試常考內容之面向對象」專題後,發佈的第二個專題,感謝你的閱讀。
本週(2019.2-18至2-22)的文章內容點爲如下幾點,更新時間爲每週一三五,能夠關注本欄持續關注,感謝你的支持。php
1、什麼是Memcache?
2、Memcache有什麼特徵?
3、Memcache的內存管理機制是什麼樣的?
4、Memcache和Memcached有什麼區別?
5、如何操做Memcache?
6、如何使用Memcache作Session共享?
7、什麼是Redis?
8、如何使用Redis?
9、使用Redis須要注意哪些問題?
10、Memcache和Redis常考的面試題
本章節的內容將會被分爲三篇文章進行講解完整塊內容,第一篇主要講解一到六,第二篇主要講解七到九,第三篇圍繞第十點。html
如下正文的部份內容來自《PHP程序員面試筆試寶典》書籍,若是轉載請保留出處:程序員
Memcache是一個開源、免費、高性能的分佈式對象緩存系統,它基於一個存儲鍵/值對的hashmap來存儲數據到內存中。它的做用是減小對數據庫的讀取以提升Web應用的性能。雖然它的守護進程(daemon )是用 C語言實現的,可是客戶端能夠用任何語言來編寫,並經過Memcache協議與守護進程通訊。須要注意的是,當某個服務器中止運行或崩潰了,全部存放在該服務器上的鍵/值對都將丟失。Memcache的服務器端沒有提供分佈式功能,各個Memcache應用不會互相通訊以共享信息。想要實現分佈式通訊,能夠搭建幾個Memcache應用,經過算法實現此效果。
下面介紹Memcache的兩個重要概念。slab:爲了防止內存碎片化,Memcache服務器端會預先將數據空間劃分爲一系列slab;舉個例子,如今有一個100m3的房間,爲了合理規劃這個房間放置東西,會在這個房間裏放置30個1m3的盒子、20個1.25m3的盒子、15個1.5m3的盒子……這些盒子就是slab。
LRU:最近最少使用算法;當同一個slab的格子滿了,這時須要新加一個值時,不會考慮將這個新數據放到比當前slat更大的空閒slab,而是使用LRU移除舊數據,放入這個新數據。web
Memcache的特徵以下:
1)協議簡單。
2)基於libevent的事件處理。
3)內置內存存儲方式。
4)Memcached不互相通訊的分佈式。
Memcache的特性以下:
(1)單個item 最大的數據爲1MB。
(2)單進程最大的使用內存爲2GB,須要更多內存時可開多個端口。
(3)Memcached是多線程,非阻塞io複用的網絡模型,Redis是單線程。
(4)鍵長最大爲250字節。面試
Memcache將內存分割成各類尺寸的塊(chunk),並把尺寸相同的塊分紅組(chunk的集合)。page是分配給slab的內存空間,默認是1MB,根據slab大小切分紅chunk,chunk是用戶緩存記錄的內存空間,slab class是特定chunk的組。
在存儲數據時,Memcache會壓縮數據的大小進行存儲,通常壓縮後的數據爲原數據大小的30%左右,從而節省了70%的傳輸性能消耗。若是存儲的數是小於100字節的鍵值對,那麼壓縮後可能帶來膨脹,但Memcache都是按照固定大小分塊存儲的,最小也有88B,因此小數據帶來的壓縮膨脹也並不會有什麼影響。
具體流程以下圖所示。算法
本身整理了一篇「如何解決Memcache的緩存雪崩現象?」的文章,關注公衆號:「琉憶編程庫」,回覆:「me」,我發給你。
其實 memcache 和 memcached 說的是 PHP 的擴展。
Memcache是一個自由和開放源代碼、高性能、分配的內存對象緩存系統。用於加速動態web應用程序,減輕數據庫負載。它能夠應對任意多個鏈接,使用非阻塞的網絡IO。因爲它的工做機制是在內存中開闢一塊空間,而後創建一個Hash表,Memcached自管理這些Hash表。
Memcache是該系統的項目名稱,Memcached是該系統的主程序文件(字母d能夠理解爲daemon),以守護程序方式運行於一個或多個服務器中,隨時接受客戶端的鏈接操做,使用共享內存存取數據。
Memcached處理的原子是每個(key,value)對(如下簡稱kv對),key會經過一個hash算法轉化成hash-key,便於查找、對比以及作到儘量的散列。同時,memcached用的是一個二級散列,經過一張大hash表來維護。
Memcached有兩個核心組件組成:服務端(Server)和客戶端(Client),在一個memcached的查詢中,Client先通 過計算key的hash值來肯定kv對所處在的Server位置。當Server肯定後,客戶端就會發送一個查詢請求給對應的Server,讓它來查找確 切的數據。由於這之間沒有交互以及多播協議,因此 memcached交互帶給網絡的數據庫
Memcached的操做命令能夠分爲存儲命令、查找命令、統計命令等三大類。
第一類,Memcached的存儲命令:編程
第二類,Memcached的查找命令:segmentfault
第三類,Memcached的統計命令:緩存
使用示例代碼參考:
<?php
$m = new Memcached();
$m->addServer("127.0.0.1",11211); //鏈接Memcache服務器
$m->set("mkey","123",600);//設置一個鍵名爲mkey,值爲123,600s過時,0爲永久有效
echo $m->get("mkey");//輸出123,get能夠獲取鍵名爲mkey的值
$m->delete("mkey");//刪除鍵名爲mkey的值
?>
具體所有的使用方法不在此一一羅列,可根據上面的方法表和參考示例進行模仿使用。
默認狀態下,PHP使用文件方式作Session存儲,磁盤的I/O性能確定沒有內存中存取快,所以改用memcache來存儲Session在讀寫速度上會快不少,並且在多臺服務器集羣時,使用memcahced可以有效地解決Session共享的問題。
咱們配置好memcached服務器後,修改php.ini配置文件的代碼:
session.save_handler = memcache
session.save_path = 「tcp://127.0.0.1:11211」
也可使用在網站目錄下放置Apache的.htaccess文件:
php_value session.save_handler 「memcache」
php_value session.save_path 「tcp://127.0.0.1:11211」
執行PHP腳本時寫入如下兩行:
ini_set(「session.save_handler」,」memcache」);
ini_set(「session.save_path」,」tcp://127.0.0.1:11211」);
能夠在使用多個memcached服務器時用都好隔開,還能夠額外帶參數:persistent、weight、timeout、retry_interval等。例如:
$session_save_path = 「tcp://<memcache_server1>:11211?persistent=1&weight=1&timeout=1&retry_interval=15,udp://<memcache_server2>:11211」;
若是想使用udp支持,須要確保你的memcached服務器啓用,也確保Web服務器鏈接到memcache服務器端口正常。從新啓動Apache後,將開始使用的memcache存儲PHP的Session。
測試案例:
<?php
Session_start();
$_SESSION[‘test’] = time();
echo $_SESSION[‘test’].」<br>」;
echo session_id();
?>
測試memcache是否已存儲成功,經過sessionid去取對應的數據:
$m = memcache_connect(‘localhost’,11211);
echo $m->get(「13765595df9dsa8f9dsa8fa9sf8saf865」);
獲得結果:
17559898989
若是使用memcached做爲Session存儲,要確保memcached的服務正常工做,不然Session相關功能將不起做用,這樣PHP的處理就多了一層外面的依賴。由於memcached是使用內存的,這樣當用戶量比較大時,就可能因爲內存方面緣由致使Session時長上的問題,Session的實際失效時長達不到設定的失效時長(由memcached在內存不夠時的處理機制決定)。
Memcache可擴展考察的內容有不少,因爲整理的篇幅內容不少,在此只是羅列了廣泛遇到的Memcache相關的知識考點。額外的考點還有:
(1)Memcache的工做流程是什麼樣的?
(2)Memcache如何實現分佈式?
(3)Memcache的分佈式算法有哪些?
(4)使用Memcache有哪些技術限制?
(5)Memcache和Redis有什麼相同和區別的地方?
更多相關面試知識點能夠閱讀《PHP程序員面試筆試寶典》。
預告:PHP面試常考內容之Memcache和Redis(2)將於本週三(2019.2-20)更新。
以上內容摘自《PHP程序員面試筆試寶典》書籍,該書已在天貓、京東、噹噹等電商平臺銷售。
更多PHP相關的面試知識、考題能夠關注公衆號獲取:琉憶編程庫
對本文有什麼問題或建議均可以進行留言,我將不斷完善追求極致,感謝大家的支持。