史上最全Redis面試49題(含答案):哨兵+複製+事務+集羣+持久化等

繼續最全Java面試答案系列篇,已經持續的更新了最全mysql、spring、多線程等面試答案。本文篇幅過長,建議收藏後慢慢細看,但願能對你的面試之旅有所幫助!mysql

文末有該最全系列答案獲取方式哦~web

Redis支持哪幾種數據類型?
支持多種類型的數據結構
1.string:最基本的數據類型,二進制安全的字符串,最大512M。
2.list:按照添加順序保持順序的字符串列表。
3.set:無序的字符串集合,不存在重複的元素。
4.sorted set:已排序的字符串集合。
5.hash:key-value對的一種集合。面試

clipboard.png

Redis主要有哪些功能?
1.哨兵(Sentinel)和複製(Replication)
Redis服務器毫無徵兆的罷工是個麻煩事,如何保證備份的機器是原始服務器的完整備份呢?這時候就須要哨兵和複製。redis

哨兵Sentinel能夠管理多個Redis服務器,它提供了監控,提醒以及自動的故障轉移的功能,Replication則是負責讓一個Redis服務器能夠配備多個備份的服務器。算法

Redis也是利用這兩個功能來保證Redis的高可用的。spring

2.事務
不少狀況下咱們須要一次執行不止一個命令,並且須要其同時成功或者失敗。redis對事務的支持也是源自於這部分需求,即支持一次性按順序執行多個命令的能力,並保證其原子性。sql

3.LUA腳本
在事務的基礎上,若是咱們須要在服務端一次性的執行更復雜的操做(包含一些邏輯判斷),則lua就能夠排上用場了。數據庫

4.持久化
redis的持久化指的是redis會把內存的中的數據寫入到硬盤中,在redis從新啓動的時候加載這些數據,從而最大限度的下降緩存丟失帶來的影響。緩存

5.集羣(Cluster)
單臺服務器資源的老是有上限的,CPU資源和IO資源咱們能夠經過主從複製,進行讀寫分離,把一部分CPU和IO的壓力轉移到從服務器上,這也有點相似mysql數據庫的主從同步。安全

在Redis官方的分佈式方案出來以前,有twemproxy和codis兩種方案,這兩個方案整體上來講都是依賴proxy來進行分佈式的,下面的內容有具體集羣方案詳解。

Redis是單進程單線程的?
Redis是單進程單線程的,Redis利用隊列技術將併發訪問變爲串行訪問,消除了傳統數據庫串行控制的開銷。

Redis爲何是單線程的?
多線程處理會涉及到鎖,並且多線程處理會涉及到線程切換而消耗CPU。由於CPU不是Redis的瓶頸,Redis的瓶頸最有多是機器內存或者網絡帶寬。單線程沒法發揮多核CPU性能,不過能夠經過在單機開多個Redis實例來解決。

其它開源軟件採用的模型
Nginx:多進程單線程模型
Memcached:單進程多線程模型

使用Redis的優點?
1.速度快,由於數據存在內存中,相似於HashMap,HashMap的優點就是查找和操做的時間複雜度都是O(1)

  1. 支持豐富數據類型,支持string,list,set,sorted set,hash

3.支持事務,操做都是原子性,所謂的原子性就是對數據的更改要麼所有執行,要麼所有不執行

  1. 豐富的特性:可用於緩存,消息,按key設置過時時間,過時後將會自動刪除

Redis單點吞吐量
單點TPS達到8萬/秒,QPS達到10萬/秒,補充下TPS和QPS的概念

1.QPS: 應用系統每秒鐘最大能接受的用戶訪問量
每秒鐘處理完請求的次數,注意這裏是處理完,具體是指發出請求到服務器處理完成功返回結果。能夠理解在server中有個counter,每處理一個請求加1,1秒後counter=QPS。
2.TPS: 每秒鐘最大能處理的請求數
每秒鐘處理完的事務次數,一個應用系統1s能完成多少事務處理,一個事務在分佈式處理中,可能會對應多個請求,對於衡量單個接口服務的處理能力,用QPS比較合理。

Redis相比memcached有哪些優點?
1.memcached全部的值均是簡單的字符串,Redis做爲其替代者,支持更爲豐富的數據類型
2.Redis的速度比memcached快不少
3.Redis能夠持久化其數據
4.Redis支持數據的備份,即master-slave模式的數據備份。

Redis有哪幾種數據淘汰策略?
在Redis中,容許用戶設置最大使用內存大小server.maxmemory,當Redis 內存數據集大小上升到必定大小的時候,就會施行數據淘汰策略。
1.volatile-lru:從已設置過時的數據集中挑選最近最少使用的淘汰
2.volatile-ttr:從已設置過時的數據集中挑選將要過時的數據淘汰
3.volatile-random:從已設置過時的數據集中任意挑選數據淘汰
4.allkeys-lru:從數據集中挑選最近最少使用的數據淘汰
5.allkeys-random:從數據集中任意挑選數據淘汰
6.noenviction:禁止淘汰數據
redis淘汰數據時還會同步到aof

Redis集羣方案應該怎麼作?都有哪些方案?
1.twemproxy
2.codis,目前用的最多的集羣方案,基本和twemproxy一致的效果,但它支持在 節點數量改變狀況下,舊節點數據可恢復到新hash節點。
3.Redis cluster3.0自帶的集,特色在於他的分佈式算法不是一致性hash,而是hash槽的概念,以及自身支持節點設置從節點。

具體請查看:高併發架構系列:詳解Redis的存儲類型、集羣架構、以及應用場景

Redis讀寫分離模型
經過增長Slave DB的數量,讀的性能能夠線性增加。爲了不Master DB的單點故障,集羣通常都會採用兩臺Master DB作雙機熱備,因此整個集羣的讀和寫的可用性都很是高。

讀寫分離架構的缺陷在於,不論是Master仍是Slave,每一個節點都必須保存完整的數據,若是在數據量很大的狀況下,集羣的擴展能力仍是受限於單個節點的存儲能力,並且對於Write-intensive類型的應用,讀寫分離架構並不適合。

Redis數據分片模型
爲了解決讀寫分離模型的缺陷,能夠將數據分片模型應用進來。
能夠將每一個節點當作都是獨立的master,而後經過業務實現數據分片。
結合上面兩種模型,能夠將每一個master設計成由一個master和多個slave組成的模型。

Redis提供了哪幾種持久化方式?
RDB持久化方式可以在指定的時間間隔能對你的數據進行快照存儲
AOF持久化方式記錄每次對服務器寫的操做,當服務器重啓的時候會從新執行這些命令來恢復原始的數據,AOF命令以Redis協議追加保存每次寫的操做到文件末尾.Redis還能對AOF文件進行後臺重寫,使得AOF文件的體積不至於過大.
若是你只但願你的數據在服務器運行的時候存在,你也能夠不使用任何持久化方式.

你也能夠同時開啓兩種持久化方式, 在這種狀況下, 當Redis重啓的時候會優先載入AOF文件來恢復原始的數據,由於在一般狀況下AOF文件保存的數據集要比RDB文件保存的數據集要完整.

最重要的事情是瞭解RDB和AOF持久化方式的不一樣,讓咱們以RDB持久化方式開始。

如何選擇合適的持久化方式?

  1. Redis主要提供了兩種持久化機制:RDB和AOF

2.RDB

默認開啓,會按照配置的指定時間將內存中的數據快照到磁盤中,建立一個dump.rdb文件,Redis啓動時再恢復到內存中。

Redis會單首創建fork()一個子進程,將當前父進程的數據庫數據複製到子進程的內存中,而後由子進程寫入到臨時文件中,持久化的過程結束了,再用這個臨時文件替換上次的快照文件,而後子進程退出,內存釋放。

須要注意的是,每次快照持久化都會將主進程的數據庫數據複製一遍,致使內存開銷加倍,若此時內存不足,則會阻塞服務器運行,直到複製結束釋放內存;都會將內存數據完整寫入磁盤一次,因此若是數據量大的話,並且寫操做頻繁,必然會引發大量的磁盤I/O操做,嚴重影響性能,而且最後一次持久化後的數據可能會丟失;

3.AOF
以日誌的形式記錄每一個寫操做(讀操做不記錄),只需追加文件但不能夠改寫文件,Redis啓動時會根據日誌從頭至尾所有執行一遍以完成數據的恢復工做。包括flushDB也會執行。

主要有兩種方式觸發:有寫操做就寫、每秒定時寫(也會丟數據)。

由於AOF採用追加的方式,因此文件會愈來愈大,針對這個問題,新增了重寫機制,就是當日志文件大到必定程度的時候,會fork出一條新進程來遍歷進程內存中的數據,每條記錄對應一條set語句,寫到臨時文件中,而後再替換到舊的日誌文件(相似rdb的操做方式)。默認觸發是當aof文件大小是上次重寫後大小的一倍且文件大於64M時觸發。

當兩種方式同時開啓時,數據恢復Redis會優先選擇AOF恢復。通常狀況下,只要使用默認開啓的RDB便可,由於相對於AOF,RDB便於進行數據庫備份,而且恢復數據集的速度也要快不少。

開啓持久化緩存機制,對性能會有必定的影響,特別是當設置的內存滿了的時候,更是降低到幾百reqs/s。因此若是隻是用來作緩存的話,能夠關掉持久化。

Redis常見性能問題和解決方案?
(1) Master最好不要作任何持久化工做,如RDB內存快照和AOF日誌文件
(2) 若是數據比較重要,某個Slave開啓AOF備份數據,策略設置爲每秒同步一次
(3) 爲了主從複製的速度和鏈接的穩定性,Master和Slave最好在同一個局域網內
(4) 儘可能避免在壓力很大的主庫上增長從庫
(5) 主從複製不要用圖狀結構,用單向鏈表結構更爲穩定,即:Master <- Slave1 <- Slave2 <- Slave3...
這樣的結構方便解決單點故障問題,實現Slave對Master的替換。若是Master掛了,能夠馬上啓用Slave1作Master,其餘不變。

Redis支持的Java客戶端都有哪些?官方推薦用哪一個?
Redisson、Jedis、lettuce等等,官方推薦使用Redisson。

Redis哈希槽的概念?
Redis集羣沒有使用一致性hash,而是引入了哈希槽的概念,當須要在 Redis 集羣中放置一個 key-value 時,根據 CRC16(key) mod 16384的值,決定將一個key放到哪一個桶中。

Redis集羣最大節點個數是多少?
Redis集羣預分好16384個桶(哈希槽)

Redis集羣的主從複製模型是怎樣的?
爲了使在部分節點失敗或者大部分節點沒法通訊的狀況下集羣仍然可用,因此集羣使用了主從複製模型,每一個節點都會有N-1個複製品.

Redis集羣會有寫操做丟失嗎?爲何?
Redis並不能保證數據的強一致性,這意味這在實際中集羣在特定的條件下可能會丟失寫操做。

Redis集羣之間是如何複製的?
異步複製

Redis如何作內存優化?
儘量使用散列表(hashes),散列表(是說散列表裏面存儲的數少)使用的內存很是小,因此你應該儘量的將你的數據模型抽象到一個散列表裏面。好比你的web系統中有一個用戶對象,不要爲這個用戶的名稱,姓氏,郵箱,密碼設置單獨的key,而是應該把這個用戶的全部信息存儲到一張散列表裏面.

Redis回收進程如何工做的?
一個客戶端運行了新的命令,添加了新的數據。
Redi檢查內存使用狀況,若是大於maxmemory的限制, 則根據設定好的策略進行回收。

Redis回收使用的是什麼算法?
LRU算法

Redis有哪些適合的場景?
1)Session共享(單點登陸)
2)頁面緩存
3)隊列
4)排行榜/計數器
5)發佈/訂閱

最後給你們推薦一個架構交流學習羣:371067604,裏面會分享一些資深架構師錄製的視頻錄像:有Spring,MyBatis,Netty源碼分析
,高併發、高性能、分佈式、微服務架構的原理,JVM性能優化這些成爲架構師必備的知識體系。還能領取免費的學習資源,相信對於已經工做
和遇到技術瓶頸的碼友,在這個羣裏會有你須要的內容。

點擊連接加入羣聊【享學-Java技術交流羣】:https://jq.qq.com/?_wv=1027&k...

相關文章
相關標籤/搜索