前言
現在的大廠面試,尤其是一面與二面都涉及到很深的Java基礎功底及知識面,所以在面試前積極的準備面試,復習整個 Java 知識體系將變得非常重要,
小編這里整理了一份Java面試核心筆記資料,包括了包含集合,JVM,多執行緒并發,Spring,負載均衡,微服務,Redis,Dubbo,設計模式,資料結構,分布式等!
因為篇幅有限,這里小編就總結了一些常問的Redis問題,剩下的Java面試題和答案放在文章末尾,

Java面試 高頻常問的Redis問題
1.什么是 Redis?
Redis 是一個基于記憶體的高性能 key-value 資料庫,支持多種資料型別,
2. 簡單描述一下 Redis 的特點有哪些?
Redis 本質上是一個 key-value 型別的記憶體資料庫,很像 memcached,整個資料庫統統加載在記憶體當中進行操作,定期通過異步操作把資料庫資料 flush 到硬碟上進行保存,純記憶體操作,Redis 的性能非常出色,每秒可以處理超過 10 萬次讀寫操作,是已知性能最快的 key-value DB,Redis 的出色之處不僅僅是性能,Redis 最大的魅力是支持保存多種資料結構,此外單個 value 的最大限制是 1GB,不像 memcached 只能保存 1MB 的資料,因此 Redis 可以用來實作很多有用的功能,Redis 的主要缺點是資料庫容量受到物理記憶體的限制,不能用作海量資料的高性能讀寫,因此 Redis 適合的場景主要局限在較小資料量的高性能操作和運算上,
3. Redis 持久化機制有哪些? 區別是什么?優缺點是什么?
Redis 提供兩種方式進行持久化,
RDB 持久化:原理是將 Reids 在記憶體中的資料庫記錄定時 dump 到磁盤上的 RDB 持久化,
AOF(append only file)持久化:原理是將 Redis 的操作日志以追加的方式寫入檔案,
兩者的區別:
RDB 持久化是指在指定的時間間隔內將記憶體中的資料集快照寫入磁盤,實際操作程序是 fork 一個子行程,先將資料集寫入臨時檔案,寫入成功后,再替換之前的檔案,用二進制壓縮存盤,

AOF 持久化以日志的形式記錄服務器所處理的每一個寫、洗掉操作,查詢操作不會記錄,以文本的方式記錄,可以打開檔案看到詳細的操作記錄,

RDB 優點
RDB 是緊湊的二進制檔案,比較合適備份,全量復制等場景;
RDB 恢復資料遠快于 AOF,
RDB 缺點
RDB 無法實作實時或者秒級持久化;
新老版本無法兼容 RDB 格式,
AOF 優點
可以更好地保護資料不丟失;
appen-only 模式寫入性能比較高;
適合做災難性的誤洗掉緊急恢復,
AOF 缺點:
對于同一份檔案,AOF 檔案要比 RDB 快照大;
AOF 開啟后,寫的 QPS 會有所影響,相對于 RDB 來說 寫 QPS 要下降;
資料庫恢復比較慢, 不合適做冷備,
4. Redis支持的資料型別
Redis 通過 key-value 的單值不同型別來區分, 以下是支持的型別: String、List、Set、Sorted Set 、Hash,
5. 為什么 Redis 需要把所有資料放到記憶體中?
1.追求最快的資料讀取速度,如果直接磁盤讀取會非常慢;
2.為了保證資料安全,也會異步方式將資料寫入磁盤;
3.可以設定 Redis 最大使用的記憶體,若達到記憶體限值后將不能繼續存入資料,
6. Redis 是單執行緒的嗎?
Redis是單執行緒處理網路指令請求,所以不需要考慮并發安全問題,所有的網路請求都是一個執行緒處理,但不代表所有模塊都是單執行緒,
7. Redis 的快取失效策略有哪幾種?
1.定時洗掉策略在設定 key 的過期時間的同時,為該 key 創建一個定時器,讓定時器在 key 的過期時間來臨時,對 key 進行洗掉,
**優點:**保證記憶體盡快釋放,
**缺點:**若 key 過多,洗掉這些 key 會占用很多 CPU 時間, 而且每個 key 創建一個定時器,性能影響嚴重,
2.惰性洗掉策略key 過期的時候不洗掉,每次從資料庫獲取 key 的時候去檢查是否過期,若過期,則洗掉,回傳 null,
**優點:**CPU 時間占用比較少,
**缺點:**若 key 很長時間沒有被獲取, 將不會被洗掉,可能造成記憶體泄露,
3.定期洗掉策略每隔一段時間執行一次洗掉(在 redis.conf 組態檔設定 hz,1s 重繪的頻率)過期 key 操作,
**優點:**可以控制洗掉操作的時長和頻率,來減少 CPU 時間占用,可以避免惰性洗掉時候記憶體泄漏的問題,
**缺點:**對記憶體友好方面,不如定時策略對 CPU 友好方面,不如惰性策略Redis 一般采用:惰性策略 + 定期策略兩個相結合,
8. 什么是快取命中率?提高快取命中率的方法有哪些?
命中:可以直接通過快取獲取到需要的資料,
不命中:無法直接通過快取獲取到想要的資料,需要再次查詢資料庫或者執行其它的操作,原因可能是由于快取中根本不存在,或者快取已經過期,命中率越高表示使用快取作用越好,性能越高(回應時間越短、吞吐量越高),并發能力也越好,重點關注訪問頻率高且時效性相對低一些的業務資料上,利用預加載(預熱)、擴容、優化快取粒度、更新快取等手段來提高命中率,
9.Redis全域命令及資料庫管理
10.Redis設計訂單應用場景
11.Redis快取雪崩講講看?
12.什么是快取穿透?
13.Redis重啟時加載AOF與RDB的順序
14.Redis的資料結構—哈希(Hash)
15.Redis的資料結構—集合(set)
16.Redis的資料結構—字串
總結
其實面試不單單是只靠面試之前刷題那么簡單,更多的還是平時的積累,
小編整理了大廠java程式員面試涉及到的絕大部分面試題及答案免費分享給大家,希望能幫助到大家面試前的復習,也節省大家在網上搜索資料的時間來學習,有需要的朋友可以看下面的免費領取方式!
↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓
領資料點這里:暗號CSDN


領資料點這里:暗號CSDN
↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑
最后感謝大家的支持,希望小編整理的資料能夠幫助到大家!也祝愿大家都能夠升職加薪!

轉載請註明出處,本文鏈接:https://www.uj5u.com/yidong/171983.html
標籤:其他
下一篇:Hadoop搭建完全分布式集群
