成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

PHP面試??純热葜甅emcache和Redis(3)

zhaochunqi / 1575人閱讀

摘要:自己整理了一篇不同等級面試都問什么的文章,關注公眾號琉憶編程庫,回復等級,我發(fā)給你。

你好,是我琉憶。
今天是周五了,再上一天班就周末了,提前祝大家周末愉快。嘿嘿。
這篇文章是本周Memcache和Redis內存數(shù)據庫??嫉膶n}。
本周一和周三更新的文章路徑:
PHP面試??純热葜甅emcache和Redis(1)
PHP面試??純热葜甅emcache和Redis(2)
本周(2019.2-18至2-22)的文章內容點為以下幾點,更新時間為每周一三五,可以關注本欄持續(xù)關注,感謝你的支持。

一、什么是Memcache?
二、Memcache有什么特征?
三、Memcache的內存管理機制是什么樣的?
四、Memcache和Memcached有什么區(qū)別?
五、如何操作Memcache?
六、如何使用Memcache做Session共享?
七、什么是Redis?
八、如何使用Redis?
九、使用Redis需要注意哪些問題?
十、新增:Redis和Memcache有什么不同?
十一、新增:Redis如何實現(xiàn)持久化?
十二、Memcache和Redis??嫉拿嬖囶}

本章節(jié)的內容將會被分為三篇文章進行講解完整塊內容,第一篇主要講解一到六,第二篇主要講解七到十一(新增了十和十一),第三篇圍繞第十二點。

自己整理了一篇“PHP不同等級面試都問什么?”的文章,關注公眾號:“琉憶編程庫”,回復:“等級”,我發(fā)給你。

以下正文的部分內容來自《PHP程序員面試筆試真題解析》書籍,如果轉載請保留出處:


十二、Memcache和Redis??嫉拿嬖囶} 【真題1】Memcache的工作原理是什么?

答案:Memcache的工作就是在專門的機器內存里維護一張巨大的hash表,存儲經常被讀寫的一些文件與數(shù)據,從而極大地提高網站的運行效率。 ?
Memcache的程序運行在一個或多個服務器中,Memcache把全部的數(shù)據保存在內存中,通過hash表的方式,每條數(shù)據由key/value的形式構成,隨時接受客戶端的請求,然后返回結果。

客戶端與Memcache建立連接后,存儲對象主要是通過唯一的key存儲value到內存中,取數(shù)據時通過這個key從內存中獲取對應的value。由于Memcache的數(shù)據是存儲在內存中而不是保存在cache文件中,所以Memcache訪問比較快,但是由于這些數(shù)據不是永久化存儲,所以不建議存儲重要數(shù)據在Memcache中,因為重啟服務器后這些數(shù)據就會消失。


【真題2】Memcache的優(yōu)點有哪些?

答案:Memcache是一個高性能的分布式內存對象緩存系統(tǒng),主要通過在內存里維護一個巨大的hash表進行數(shù)據緩存。它主要是將數(shù)據存儲到內存中,然后從內存中讀取數(shù)據,從而提高讀取速度。它主要通過key-value的形式存儲各種數(shù)據,包括圖像、視頻、文件等。
它具有以下幾點優(yōu)點:

(1)支持多臺服務器使用Memcache,由于Memcache的存儲數(shù)據大小必須小于內存的大小,所以可以將Memcache使用在多臺服務器上,增加緩存容量;

(2)支持均衡請求。當使用多臺Memcache服務器時,可以均衡請求,避免所有請求都進入一臺Memcache服務器中,避免服務器掛掉而丟失數(shù)據;

(3)支持分布式,可以解決緩存本身水平線性擴展的問題和緩存大并發(fā)下的自身性能問題,避免緩存的單點故障問題;

(4)支持部分容災問題,如果多臺服務器存儲了Memcache數(shù)據,其中一臺Memcache服務器掛掉,部分請求還是可以在其它服務器的Memcache中命中,為修復掛掉的服務器爭取一些時間。


【真題3】如何合理地使用Memcache緩存?如果緩存數(shù)據量過大,那么如何部署?(分布式,緩存時間,優(yōu)化緩存數(shù)據)

答案:如果要合理地使用Memcache緩存,那么需要注意以下幾點內容:

(1)因為Memcache支持最大的存儲對象大小為1M,所以當合理使用Memcache緩存時,要求不能往Memcache存儲一個大于1MB的數(shù)據;

(2)Memcache存儲的所有數(shù)據,如果數(shù)據大小分布于各種chunk大小區(qū)間,從64B到1MB都有,那么會造成內存的極大浪費和Memcache的異常。所以需要注意數(shù)據大小的分布區(qū)間;

(3)key的長度不能大于250個字符;

(4)虛擬主機不允許運行Memcache服務,所以不能把Memcache部署到虛擬主機中;

(5)因為Memcache可以輕松訪問到,所以可以運行在不安全的環(huán)境中,如果對數(shù)據安全要求高,那么需要著重考慮運行環(huán)境的安全問題;

(6)因為Memcache存儲的數(shù)據都在內存中,服務器掛掉就會清空內存,所以緩存中的數(shù)據盡量是丟失了也不會有太大影響的數(shù)據。

如果緩存中的數(shù)據量過大,那么可以采取以下的辦法:
(1)使用Memcache服務器集群的方法,首先是將數(shù)據安排放在不同的Memcache服務器上,可以將不同硬件服務器上的Memcache服務器再做成一個數(shù)據互相備份的組,避免數(shù)據的單點丟失問題;

(2)緩存數(shù)據到數(shù)據庫中,在數(shù)據庫中先建一張表來說明Memcache服務器集群中緩存數(shù)據的存放邏輯,然后實現(xiàn)把緩存數(shù)據存到數(shù)據庫中,可以保證數(shù)據庫和緩存的數(shù)據雙向存取。


【真題4】Redis 與 Memcache有什么區(qū)別?

答案:Redis是一個完全開源免費的高性能key-value數(shù)據庫,具有豐富的數(shù)據類型,可以支持數(shù)據的持久化,將內存中的數(shù)據保存在磁盤中,當重啟服務器時可以再次加載使用。

Memcache是一個高性能的分布式內存對象緩存系統(tǒng),用于動態(tài)的Web應用中幫助數(shù)據庫減輕負擔,在內存中緩存數(shù)據和對象,減少每次訪問數(shù)據時對數(shù)據庫的訪問次數(shù),從而提高訪問速度。

它們具有以下幾點區(qū)別:
(1)Redis和Memcache的最大區(qū)別是,雖然Memcache和Redis都是將數(shù)據存在內存中,是內存數(shù)據庫,但Redis存儲時,并不是所有的數(shù)據都一直存儲在內存中,而Memcache存儲時,數(shù)據都存在內存中;

(2)數(shù)據安全問題,由于memecache 把數(shù)據全部存在內存之中,服務器掛掉后,重啟服務器數(shù)據就會丟失,而Redis可以定期保存數(shù)據到磁盤中做持久化存儲,當需要時可以再加載使用。對于災難恢復,Memcache掛掉后,數(shù)據不可恢復,但Redis數(shù)據丟失后可以通過aof恢復;

(3)Redis支持多種數(shù)據結構存儲,例如list,set,hash等數(shù)據結構的存儲,而Memcache主要是在內存中維護一個統(tǒng)一的巨大的hash表進行存儲數(shù)據,只支持簡單的key/value類型的數(shù)據存儲,但Memcache可以存儲圖片、視頻、文件及數(shù)據庫檢索結果等;

(4)數(shù)據備份問題,Redis支持數(shù)據的備份,即master-slave模式的數(shù)據備份。而Memcache不支持數(shù)據持久化,所以無法進行數(shù)據備份;

(5)在內存使用率上,使用簡單的key-value存儲的話,Memcached的內存利用率更高,而如果Redis采用hash結構來做key-value存儲,由于其組合式的壓縮,其內存利用率會高于Memcached。具體和應用場景、數(shù)據特性有關;

(6)在線程上的比較,Memcache是支持多線程的,而Redis只支持單線程,所以CPU利用方面Memcache優(yōu)于Redis;

(7)它們的擴展都需要做集群;實現(xiàn)方式:master-slave、Hash;

(8)數(shù)據的讀寫方面,Redis和Memcache在寫入性能上面差別不大,讀取性能上面尤其是批量讀取性能上Memcache更強。


【真題5】Redis集群方案應該怎么做?都有哪些方案?

答案:1.twemproxy,大概概念是,它類似于一個代理方式,使用方法和普通redis無任何區(qū)別,設置好它下屬的多個redis實例后,使用時在本需要連接redis的地方改為連接twemproxy,它會以一個代理的身份接收請求并使用一致性hash算法,將請求轉接到具體redis,將結果再返回twemproxy。使用方式簡便(相對redis只需修改連接端口),對舊項目擴展的首選。 問題:twemproxy自身單端口實例的壓力,使用一致性hash后,對redis節(jié)點數(shù)量改變時候的計算值的改變,數(shù)據無法自動移動到新的節(jié)點。

2.codis,目前用的最多的集群方案,基本和twemproxy一致的效果,但它支持在 節(jié)點數(shù)量改變情況下,舊節(jié)點數(shù)據可恢復到新hash節(jié)點。

3.redis cluster3.0自帶的集群,特點在于他的分布式算法不是一致性hash,而是hash槽的概念,以及自身支持節(jié)點設置從節(jié)點。具體看官方文檔介紹。

4.在業(yè)務代碼層實現(xiàn),起幾個毫無關聯(lián)的redis實例,在代碼層,對key 進行hash計算,然后去對應的redis實例操作數(shù)據。 這種方式對hash層代碼要求比較高,考慮部分包括,節(jié)點失效后的替代算法方案,數(shù)據震蕩后的自動腳本恢復,實例的監(jiān)控,等等。


自己整理了一篇“PHP不同等級面試都問什么?”的文章,關注公眾號:“琉憶編程庫”,回復:“等級”,我發(fā)給你。

【真題6】Redis有哪些適合的場景?

答案:(1)、會話緩存(Session Cache)

最常用的一種使用Redis的情景是會話緩存(session cache)。用Redis緩存會話比其他存儲(如Memcached)的優(yōu)勢在于:Redis提供持久化。當維護一個不是嚴格要求一致性的緩存時,如果用戶的購物車信息全部丟失,大部分人都會不高興的,現(xiàn)在,他們還會這樣嗎?

幸運的是,隨著 Redis 這些年的改進,很容易找到怎么恰當?shù)氖褂肦edis來緩存會話的文檔。甚至廣為人知的商業(yè)平臺Magento也提供Redis的插件。

(2)、全頁緩存(FPC)

除基本的會話token之外,Redis還提供很簡便的FPC平臺。回到一致性問題,即使重啟了Redis實例,因為有磁盤的持久化,用戶也不會看到頁面加載速度的下降,這是一個極大改進,類似PHP本地FPC。

再次以Magento為例,Magento提供一個插件來使用Redis作為全頁緩存后端。

此外,對WordPress的用戶來說,Pantheon有一個非常好的插件 wp-redis,這個插件能幫助你以最快速度加載你曾瀏覽過的頁面。

(3)、隊列

Reids在內存存儲引擎領域的一大優(yōu)點是提供 list 和 set 操作,這使得Redis能作為一個很好的消息隊列平臺來使用。Redis作為隊列使用的操作,就類似于本地程序語言(如Python)對 list 的 push/pop 操作。

如果你快速的在Google中搜索“Redis queues”,你馬上就能找到大量的開源項目,這些項目的目的就是利用Redis創(chuàng)建非常好的后端工具,以滿足各種隊列需求。例如,Celery有一個后臺就是使用Redis作為broker,你可以從這里去查看。

(4),排行榜/計數(shù)器

Redis在內存中對數(shù)字進行遞增或遞減的操作實現(xiàn)的非常好。集合(Set)和有序集合(Sorted Set)也使得我們在執(zhí)行這些操作的時候變的非常簡單,Redis只是正好提供了這兩種數(shù)據結構。所以,我們要從排序集合中獲取到排名最靠前的10個用戶–我們稱之為“user_scores”,我們只需要像下面一樣執(zhí)行即可:

當然,這是假定你是根據你用戶的分數(shù)做遞增的排序。如果你想返回用戶及用戶的分數(shù),你需要這樣執(zhí)行:

ZRANGE user_scores 0 10 WITHSCORES

Agora Games就是一個很好的例子,用Ruby實現(xiàn)的,它的排行榜就是使用Redis來存儲數(shù)據的,你可以在這里看到。

(5)、發(fā)布/訂閱

最后(但肯定不是最不重要的)是Redis的發(fā)布/訂閱功能。發(fā)布/訂閱的使用場景確實非常多。我已看見人們在社交網絡連接中使用,還可作為基于發(fā)布/訂閱的腳本觸發(fā)器,甚至用Redis的發(fā)布/訂閱功能來建立聊天系統(tǒng)?。ú唬@是真的,你可以去核實)。

【真題7】Redis持久化數(shù)據和緩存怎么做擴容?

答案:如果Redis被當做緩存使用,使用一致性哈希實現(xiàn)動態(tài)擴容縮容。

如果Redis被當做一個持久化存儲使用,必須使用固定的keys-to-nodes映射關系,節(jié)點的數(shù)量一旦確定不能變化。否則的話(即Redis節(jié)點需要動態(tài)變化的情況),必須使用可以在運行時進行數(shù)據再平衡的一套系統(tǒng),而當前只有Redis集群可以做到這樣。


【真題8】Redis回收進程如何工作的?

答案:一個客戶端運行了新的命令,添加了新的數(shù)據。

Redi檢查內存使用情況,如果大于maxmemory的限制, 則根據設定好的策略進行回收。

一個新的命令被執(zhí)行,等等。

所以我們不斷地穿越內存限制的邊界,通過不斷達到邊界然后不斷地回收回到邊界以下。

如果一個命令的結果導致大量內存被使用(例如很大的集合的交集保存到一個新的鍵),不用多久內存限制就會被這個內存使用量超越。


【真題9】都有哪些辦法可以降低Redis的內存使用情況呢?

答案:如果你使用的是32位的Redis實例,可以好好利用Hash,list,sorted set,set等集合類型數(shù)據,因為通常情況下很多小的Key-Value可以用更緊湊的方式存放到一起。


【真題10】你知道有哪些Redis分區(qū)實現(xiàn)方案?

答案:客戶端分區(qū)就是在客戶端就已經決定數(shù)據會被存儲到哪個redis節(jié)點或者從哪個redis節(jié)點讀取。大多數(shù)客戶端已經實現(xiàn)了客戶端分區(qū)。

代理分區(qū) 意味著客戶端將請求發(fā)送給代理,然后代理決定去哪個節(jié)點寫數(shù)據或者讀數(shù)據。代理根據分區(qū)規(guī)則決定請求哪些Redis實例,然后根據Redis的響應結果返回給客戶端。redis和memcached的一種代理實現(xiàn)就是Twemproxy

查詢路由(Query routing) 的意思是客戶端隨機地請求任意一個redis實例,然后由Redis將請求轉發(fā)給正確的Redis節(jié)點。Redis Cluster實現(xiàn)了一種混合形式的查詢路由,但并不是直接將請求從一個redis節(jié)點轉發(fā)到另一個redis節(jié)點,而是在客戶端的幫助下直接redirected到正確的redis節(jié)點。


自己根據不同PHP不同等級面試時,會問哪些PHP??嫉闹R點整理成了一篇文章
自己整理了一篇“PHP不同等級面試都問什么?”的文章,關注公眾號:“琉憶編程庫”,回復:“等級”,我發(fā)給你。

更多相關面試常考真題可以閱讀《PHP程序員面試筆試真題解析》。

預告:下周(2019.2.25至2019.3.1)一三五將更新的主題為:PHP面試之會話控制、網絡協(xié)議、相關的面試題

以上內容摘自《PHP程序員面試筆試真題解析》書籍,該書已在天貓、京東、當當?shù)入娚唐脚_銷售。

更多PHP相關的面試知識、考題可以關注公眾號獲?。?strong>琉憶編程庫

對本文有什么問題或建議都可以進行留言,我將不斷完善追求極致,感謝你們的支持。

文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉載請注明本文地址:http://systransis.cn/yun/61747.html

相關文章

  • PHP面試常考內容MemcacheRedis3

    摘要:自己整理了一篇不同等級面試都問什么的文章,關注公眾號琉憶編程庫,回復等級,我發(fā)給你。 你好,是我琉憶。今天是周五了,再上一天班就周末了,提前祝大家周末愉快。嘿嘿。這篇文章是本周Memcache和Redis內存數(shù)據庫??嫉膶n}。本周一和周三更新的文章路徑:PHP面試常考內容之Memcache和Redis(1)PHP面試??純热葜甅emcache和Redis(2)本周(2019.2-18至...

    Lionad-Morotar 評論0 收藏0
  • PHP面試常考內容MemcacheRedis(2)

    摘要:繼周一發(fā)布的面試??純热葜秃?,這是第二篇,感謝你的支持和閱讀。預告面試??純热葜蛯⒂诒局芪甯?。以上內容摘自程序員面試筆試寶典書籍,該書已在天貓京東當當?shù)入娚唐脚_銷售。 你好,是我琉憶。繼周一(2019.2-18)發(fā)布的PHP面試??純热葜甅emcache和Redis(1)后,這是第二篇,感謝你的支持和閱讀。本周(2019.2-18至2-22)的文章內容點為以下幾點,更新時間為每周...

    Eric 評論0 收藏0
  • PHP面試???/em>內容MemcacheRedis(2)

    摘要:繼周一發(fā)布的面試常考內容之和后,這是第二篇,感謝你的支持和閱讀。預告面試??純热葜蛯⒂诒局芪甯?。以上內容摘自程序員面試筆試寶典書籍,該書已在天貓京東當當?shù)入娚唐脚_銷售。 你好,是我琉憶。繼周一(2019.2-18)發(fā)布的PHP面試??純热葜甅emcache和Redis(1)后,這是第二篇,感謝你的支持和閱讀。本周(2019.2-18至2-22)的文章內容點為以下幾點,更新時間為每周...

    sewerganger 評論0 收藏0
  • PHP面試???/em>內容MemcacheRedis(1)

    摘要:以下正文的部分內容來自程序員面試筆試寶典書籍,如果轉載請保留出處一什么是是一個開源免費高性能的分布式對象緩存系統(tǒng),它基于一個存儲鍵值對的來存儲數(shù)據到內存中。預告面試??純热葜蛯⒂诒局苋?。 你好,是我琉憶。繼上周(2019.2-11至2-15)發(fā)布的PHP面試??純热葜嫦驅ο髮n}后,發(fā)布的第二個專題,感謝你的閱讀。本周(2019.2-18至2-22)的文章內容點為以下幾點,更新時...

    wenyiweb 評論0 收藏0
  • PHP面試???/em>內容MemcacheRedis(1)

    摘要:以下正文的部分內容來自程序員面試筆試寶典書籍,如果轉載請保留出處一什么是是一個開源免費高性能的分布式對象緩存系統(tǒng),它基于一個存儲鍵值對的來存儲數(shù)據到內存中。預告面試常考內容之和將于本周三更新。 你好,是我琉憶。繼上周(2019.2-11至2-15)發(fā)布的PHP面試??純热葜嫦驅ο髮n}后,發(fā)布的第二個專題,感謝你的閱讀。本周(2019.2-18至2-22)的文章內容點為以下幾點,更新時...

    nanfeiyan 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<