看完令你大徹大悟的22道經典Redis面試題,附帶答案(下)

      網友投稿 712 2025-04-01

      1、Redis 集群的主從復制模型是怎樣的?


      答: 為了使在部分節點失敗或者大部分節點無法通信的情況下集群仍然可用, 所以集群使用了主從復制模型,每個節點都會有 N-1 個復制品。

      2、Redis 集群會有寫操作丟失嗎?為什么?

      答:Redis 并不能保證數據的強一致性,這意味這在實際中集群在特定的條件下可能會丟失寫操作。

      3、Redis 集群之間是如何復制的?

      答: 異步復制。

      4、Redis 集群最大節點個數是多少?

      答: 16384 個。

      5、Redis 集群如何選擇數據庫?

      答: Redis 集群目前無法做數據庫選擇, 默認在 0 數據庫。

      6、怎么測試 Redis 的連通性?

      答: 使用 ping 命令。

      7、怎么理解 Redis 事務?

      答:

      1) 事務是一個單獨的隔離操作: 事務中的所有命令都會序列化、按順序地執行。事務在執行的過程中, 不會被其他客戶端發送來的命令請求所打斷。

      2) 事務是一個原子操作: 事務中的命令要么全部被執行, 要么全部都不執行。

      8、Redis 事務相關的命令有哪幾個?

      答: MULTI、EXEC、DISCARD、WATCH。

      9、Redis key 的過期時間和永久有效分別怎么設置?

      答: EXPIRE 和 PERSIST 命令。

      10、Redis 如何做內存優化?

      答: 盡可能使用散列表( hashes), 散列表( 是說散列表里面存儲的數少) 使用的內存非常小, 所以你應該盡可能的將你的數據模型抽象到一個散列表里面。比如你的 web 系統中有一個用戶對象, 不要為這個用戶的名稱, 姓氏, 郵箱, 密碼設置單獨的 key,而是應該把這個用戶的所有信息存儲到一張散列表里面。

      11、Redis 回收進程如何工作的?

      答: 一個客戶端運行了新的命令, 添加了新的數據。Redi 檢查內存使用情況, 如果大于 maxmemory 的限制, 則根據設定好的策略進行回收。一個新的命令被執行, 等等。所以我們不斷地穿越內存限制的邊界, 通過不斷達到邊界然后不斷地回收回到邊界以下。如果一個命令的結果導致大量內存被使用( 例如很大的集合的交集保存到一個新的鍵), 不用多久內存限制就會被這個內存使用量超越。

      看完令你大徹大悟的22道經典Redis面試題,附帶答案(下)

      12、都有哪些辦法可以降低 Redis 的內存使用情況呢?

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

      13、Redis 的內存用完了會發生什么?

      答:如果達到設置的上限,Redis 的寫命令會返回錯誤信息( 但是讀命令還可以正常返回。) 或者你可以將 Redis 當緩存來使用配置淘汰機制, 當 Redis 達到內存上限時會沖刷掉舊的內容。

      14、一個 Redis 實例最多能存放多少的 keys?List、Set、Sorted Set 他們最多能存放多少元素?

      答:理論上 Redis 可以處理多達 232 的 keys,并且在實際中進行了測試,每個實例至少存放了 2 億 5 千萬的 keys。我們正在測試一些較大的值。任何 list、set、和 sorted set 都可以放 232 個元素。換句話說, Redis 的存儲極限是系統中的可用內存值。

      15、MySQL 里有 2000w 數據,redis 中只存 20w 的數據,如何保證redis 中的數據都是熱點數據?

      答: Redis 內存數據集大小上升到一定大小的時候, 就會施行數據淘汰策略。

      相關知識: Redis 提供 6 種數據淘汰策略:

      volatile-lru:從已設置過期時間的數據集( server.db[i].expires)中挑選最近最少使用的數據淘汰。

      volatile-ttl: 從已設置過期時間的數據集( server.db[i].expires) 中挑選將要過期的數據淘汰。

      volatile-random: 從已設置過期時間的數據集( server.db[i].expires) 中任意選擇數據淘汰。

      allkeys-lru: 從數據集( server.db[i].dict) 中挑選最近最少使用的數據淘汰。

      allkeys-random: 從數據集( server.db[i].dict) 中任意選擇數據淘汰。

      no-enviction( 驅逐) : 禁止驅逐數據。

      16、Redis 最適合的場景?

      1、會話緩存( Session Cache)

      最常用的一種使用 Redis 的情景是會話緩存( session cache)。用 Redis 緩存會話比其他存儲( 如 Memcached)的優勢在于:Redis 提供持久化。當維護一個不是嚴格要求一致性的緩存時, 如果用戶的購物車信息全部丟失, 大部分人都會不高興的, 現在, 他們還會這樣嗎? 幸運的是, 隨著 Redis 這些年的改進, 很容易找到怎么恰當的使用 Redis 來緩存會話的文檔。甚至廣為人知的商業平臺Magento 也提供 Redis 的插件。

      2、全頁緩存( FPC)

      除基本的會話 token 之外, Redis 還提供很簡便的 FPC 平臺?;氐揭恢滦詥栴}, 即使重啟了 Redis 實例, 因為有磁盤的持久化, 用戶也不會看到頁面加載速度的下降,這是一個極大改進,類似 PHP 本地 FPC。 再次以 Magento 為例,Magento 提供一個插件來使用 Redis 作為全頁緩存后端。 此外, 對 WordPress 的用戶來說, Pantheon 有一個非常好的插件 wp-redis, 這個插件能幫助你以最快速度加載你曾瀏覽過的頁面。

      3、隊列

      Reids 在內存存儲引擎領域的一大優點是提供 list 和 set 操作, 這使得 Redis 能作為一個很好的消息隊列平臺來使用。Redis 作為隊列使用的操作,就類似于本地程序語言( 如 Python)對 list 的 push/pop 操作。 如果你快速的在 Google 中搜索“ Redis queues”, 你馬上就能找到大量的開源項目, 這些項目的目的就是利用 Redis 創建非常好的后端工具, 以滿足各種隊列需求。例如, Celery 有一個后臺就是使用 Redis 作為 broker, 你可以從這里去查看。

      4, 排行榜/計數器

      Redis 在內存中對數字進行遞增或遞減的操作實現的非常好。集合( Set) 和有序集合( Sorted Set)也使得我們在執行這些操作的時候變的非常簡單,Redis 只是正好提供了這兩種數據結構。所以, 我們要從排序集合中獲取到排名最靠前的 10 個用戶– 我們稱之為“ user_scores”, 我們只需要像下面一樣執行即可: 當然,這是假定你是根據你用戶的分數做遞增的排序。如果你想返回用戶及用戶的分數, 你需要這樣執行: ZRANGE user_scores 0 10 WITHSCORES Agora Games 就是一個很好的例子, 用 Ruby 實現的, 它的排行榜就是使用 Redis 來存儲數據的, 你可以在這里看到。

      5、發布/訂閱

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

      17、假如 Redis 里面有 1 億個key,其中有 10w 個key 是以某個固定的已知的前綴開頭的,如果將它們全部找出來?

      答: 使用 keys 指令可以掃出指定模式的 key 列表。

      對方接著追問: 如果這個 redis 正在給線上的業務提供服務, 那使用 keys 指令會有什么問題?

      這個時候你要回答 redis 關鍵的一個特性:redis 的單線程的。keys 指令會導致線程阻塞一段時間, 線上服務會停頓, 直到指令執行完畢, 服務才能恢復。這個時候可以使用 scan 指令, scan 指令可以無阻塞的提取出指定模式的 key 列表, 但是會有一定的重復概率, 在客戶端做一次去重就可以了, 但是整體所花費的時間會比直接用 keys 指令長。

      18、如果有大量的 key 需要設置同一時間過期,一般需要注意什么?

      答:如果大量的 key 過期時間設置的過于集中,到過期的那個時間點,redis 可能會出現短暫的卡頓現象。一般需要在時間上加一個隨機值, 使得過期時間分散一些。

      19、使用過 Redis 做異步隊列么,你是怎么用的?

      答:一般使用 list 結構作為隊列,rpush 生產消息,lpop 消費消息。當 lpop 沒有消息的時候, 要適當 sleep 一會再重試。

      如果對方追問可不可以不用 sleep 呢?

      list 還有個指令叫 blpop,在沒有消息的時候,它會阻塞住直到消息到來。如果對方追問能不能生產一次消費多次呢? 使用 pub/sub 主題訂閱者模式, 可以實現1:N 的消息隊列。

      如果對方追問 pub/sub 有什么缺點?

      在消費者下線的情況下,生產的消息會丟失,得使用專業的消息隊列如 RabbitMQ 等。

      如果對方追問 redis 如何實現延時隊列?

      我估計現在你很想把面試官一棒打死如果你手上有一根棒球棍的話, 怎么問的這么詳細。但是你很克制,然后神態自若的回答道:使用 sortedset,拿時間戳作為score,消息內容作為 key 調用 zadd 來生產消息,消費者用 zrangebyscore 指令獲取 N 秒之前的數據輪詢進行處理。到這里, 面試官暗地里已經對你豎起了大拇指。但是他不知道的是此刻你卻豎起了中指, 在椅子背后。

      20、使用過 Redis 分布式鎖么,它是什么回事?

      先拿 setnx 來爭搶鎖, 搶到之后, 再用 expire 給鎖加一個過期時間防止鎖忘記了釋放。

      這時候對方會告訴你說你回答得不錯, 然后接著問如果在 setnx 之后執行 expire 之前進程意外 crash 或者要重啟維護了, 那會怎么樣?

      這時候你要給予驚訝的反饋: 唉, 是喔, 這個鎖就永遠得不到釋放了。緊接著你需要抓一抓自己得腦袋, 故作思考片刻, 好像接下來的結果是你主動思考出來的, 然后回答: 我記得 set 指令有非常復雜的參數, 這個應該是可以同時把 setnx 和expire 合成一條指令來用的! 對方這時會顯露笑容, 心里開始默念: 摁, 這小子還不錯。

      21、如何實現集群中的 session 共享存儲?

      Session 是運行在一臺服務器上的,所有的訪問都會到達我們的唯一服務器上,這樣我們可以根據客戶端傳來的 sessionID,來獲取 session,或在對應 Session 不存在的情況下( session 生命周期到了/用戶第一次登錄),創建一個新的 Session; 但是, 如果我們在集群環境下, 假設我們有兩臺服務器 A, B, 用戶的請求會由Nginx 服務器進行轉發( 別的方案也是同理), 用戶登錄時, Nginx 將請求轉發至服務器 A 上,A 創建了新的 session,并將 SessionID 返回給客戶端,用戶在瀏覽其他頁面時, 客戶端驗證登錄狀態, Nginx 將請求轉發至服務器 B, 由于 B 上并沒有對應客戶端發來 sessionId 的 session,所以會重新創建一個新的 session,并且再將這個新的 sessionID 返回給客戶端, 這樣, 我們可以想象一下, 用戶每一次操作都有 1/2 的概率進行再次的登錄, 這樣不僅對用戶體驗特別差, 還會讓服務器上的 session 激增, 加大服務器的運行壓力。

      為了解決集群環境下的 seesion 共享問題, 共有 4 種解決方案:

      粘性 session:粘性 session 是指 Ngnix 每次都將同一用戶的所有請求轉發至同一臺服務器上, 即將用戶與服務器綁定。

      服務器 session :復制即每次 session 發生變化時, 創建或者修改, 就廣播給所有集群中的服務器, 使所有的服務器上的 session 相同。

      session 共享:緩存 session, 使用 redis, memcached。4.session 持久化

      將 session 存儲至數據庫中, 像操作數據一樣才做 session。

      22、memcached 與redis 的區別?

      1、Redis 不僅僅支持簡單的 k/v 類型的數據,同時還提供 list,set,zset, hash 等數據結構的存儲。而 memcache 只支持簡單數據類型,需要客戶端自己處理復雜對象

      2、Redis 支持數據的持久化, 可以將內存中的數據保持在磁盤中, 重啟的時候可以再次加載進行使用( PS: 持久化在 rdb、aof)。

      Redis

      版權聲明:本文內容由網絡用戶投稿,版權歸原作者所有,本站不擁有其著作權,亦不承擔相應法律責任。如果您發現本站中有涉嫌抄襲或描述失實的內容,請聯系我們jiasou666@gmail.com 處理,核實后本網站將在24小時內刪除侵權內容。

      版權聲明:本文內容由網絡用戶投稿,版權歸原作者所有,本站不擁有其著作權,亦不承擔相應法律責任。如果您發現本站中有涉嫌抄襲或描述失實的內容,請聯系我們jiasou666@gmail.com 處理,核實后本網站將在24小時內刪除侵權內容。

      上一篇:Excel中利用工具選項給表格加密的操作方法(給Excel表格加密)
      下一篇:怎么插入兩頁(怎么在word兩頁中間插一頁)
      相關文章
      国产99久久亚洲综合精品| 亚洲人成网站免费播放| 青青青亚洲精品国产| 伊人久久五月丁香综合中文亚洲| 亚洲AV一二三区成人影片| 亚洲国产精品yw在线观看| 亚洲乱码无限2021芒果| 亚洲精品欧洲精品| 亚洲国产综合在线| 亚洲精品第一国产综合野| 在线aⅴ亚洲中文字幕| 亚洲国产一区二区三区在线观看| 亚洲精品国产av成拍色拍| 亚洲精品天堂无码中文字幕| 亚洲国产高清国产拍精品| 亚洲精品GV天堂无码男同| 午夜亚洲国产成人不卡在线 | 国产亚洲精品免费| 亚洲国产精品狼友中文久久久| 亚洲成A人片在线观看无码3D| 亚洲精品视频免费| 亚洲伊人久久精品影院| 亚洲国产精品无码久久SM| 亚洲成a人片77777老司机| 亚洲精品视频在线免费| 亚洲一级毛片在线观| 亚洲熟妇AV一区二区三区浪潮| 亚洲AV无码国产剧情| 亚洲精品无码久久久久AV麻豆| 激情综合色五月丁香六月亚洲| 久久精品国产69国产精品亚洲| 亚洲精品视频在线| 亚洲人成电影院在线观看| 亚洲另类无码一区二区三区| 亚洲AV成人潮喷综合网| 亚洲中文字幕无码一区二区三区| 亚洲gv白嫩小受在线观看| 亚洲最大视频网站| 亚洲日韩精品国产3区| 亚洲高清无码专区视频| 久久精品国产亚洲综合色|