十年網(wǎng)站開發(fā)經(jīng)驗 + 多家企業(yè)客戶 + 靠譜的建站團隊
量身定制 + 運營維護+專業(yè)推廣+無憂售后,網(wǎng)站問題一站解決
小編給大家分享一下Redis都有哪些面試題,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
Redis 支持哪幾種數(shù)據(jù)類型?
Redis是單進程的還是單線程的?
Redis是單進程單線程的,Redis利用隊列技術(shù)將并發(fā)訪問變?yōu)榇性L問,消除了傳統(tǒng)數(shù)據(jù)庫串行控制的開銷。
Redis為什么是單線程的?
多線程處理會設(shè)計到鎖,而且多線程處理會設(shè)計到線程切換而消耗CPU。因為CPU不會Redis的瓶頸,Redis的瓶頸最有可能是機器內(nèi)存或者網(wǎng)絡(luò)帶寬。單線程無法發(fā)揮多核CPU性能,不過可以通過在單機開啟Redis實例來解決。
Redis的優(yōu)勢
Redis和memcached有哪些優(yōu)勢
Redis有哪幾種數(shù)據(jù)淘汰策略
在Redis中,允許用戶設(shè)置大使用內(nèi)存大小server.maxmemory,當(dāng)Redis內(nèi)存數(shù)據(jù)集大小上升到一定大小的時候,就會執(zhí)行數(shù)據(jù)淘汰策略
Redis支持哪幾種持久化方式
原理是將Redis在內(nèi)存中的數(shù)據(jù)記錄定時dump到磁盤上的RDB文件
指定的時間間隔內(nèi)將內(nèi)存中的數(shù)據(jù)集快照寫入磁盤,實際操作過程是fork一個子進程,先將數(shù)據(jù)集寫入臨時文件,寫入成功后,再替換之前的文件,用二進制壓縮存儲。
原理是將Redis的操作日志以追加的方式寫入文件。
以日志的形式記錄服務(wù)器所處理的每一個寫、刪除操作,查詢操作不會記錄,以文本的方式記錄,可以打開文件看到詳細(xì)的操作記錄。當(dāng)服務(wù)器重啟的時候會重新執(zhí)行這些命令來恢復(fù)原始的數(shù)據(jù)。AOF命令以Reids協(xié)議追加保存每次寫的操作到文件末尾。Redis還能對AOF文件進行后臺重寫,使得AOF文件的體積不至于過大。
Redis兩種持久化方式優(yōu)缺點?
RDB持久化
優(yōu)點:RDB文件緊湊,體積小,網(wǎng)絡(luò)傳輸快,適合全量復(fù)制;恢復(fù)速度比AOF快很多。當(dāng)然,與AOF相比,RDB最重要的優(yōu)點之一是對性能的影響相對較小
缺點:RDB文件的致命缺點在與其數(shù)據(jù)快照的持久化方式?jīng)Q定了必然做不到實時持久化,而在數(shù)據(jù)越來越重要的今天,數(shù)據(jù)的大量丟失很多時候是無法接受的,因此AOF持久化稱為主流。此外,RDB文件需要滿足特定格式,兼容性差。
AOF持久化
與RDB持久化相對應(yīng),AOF的優(yōu)點在于支持秒級持久化、兼容性好,缺點是文件大,恢復(fù)速度慢,對性能影響大
如何選擇Redis持久化方式策略?
在介紹持久化策略之前,首先要明白無論是RDB還是AOF,持久化的開啟都是要付出性能方面的代價的。對比RDB持久化,一方面是bdsave在進行fork操作時Redis主進程會阻塞,另一方面,子進程向硬盤寫數(shù)據(jù)也會帶來IO壓力;對于AOF持久化,向硬盤寫數(shù)據(jù)的頻率大大提高(everysec策略下為秒級),IO壓力更大,設(shè)置可能造成AOF追加阻塞文件。此外,AOF文件的重寫與RDB的basave類似,會有fork時的阻塞和子進程的IO壓力問題。相對來說,由于AOF向硬盤中寫數(shù)據(jù)的頻率更高,因此對Redis主進程性能的影響會更大。
在實際生產(chǎn)環(huán)境中,根據(jù)數(shù)據(jù)量、應(yīng)用對數(shù)據(jù)的安全要求、預(yù)算限制等不同情況,會有各種各樣的持久化策略;如完全不使用任何持久化,使用RDB或AOF一種,或同事開啟RDB和AOF持久化等。此外,持久化的選擇必須與Redis的主從策略一起考慮,因為主從復(fù)制與持久化同樣具有數(shù)據(jù)備份的功能,而且主機master和從機slave可以獨立的選擇持久化方案。
Redis集群的主從復(fù)制模型是怎樣的?
為了是在部分節(jié)點失敗或者大部分節(jié)點無法通信的情況下集群仍然可用,所以集群是用了主從復(fù)制模型,每個節(jié)點都會有N-1個復(fù)制品
Redis集群會有寫操作丟失嗎?為什么?
Redis并不能保證數(shù)據(jù)強一致性,這意味著在實際中集群在特定的條件下可能會丟失寫操作
Redis集群之間是如何復(fù)制的
異步復(fù)制
Redis如何做內(nèi)存優(yōu)化
盡可能使用散列表(hashes),散列表(是說列表里面存儲的數(shù)少)使用的內(nèi)存非常小,所以你應(yīng)該盡可能的將你的數(shù)據(jù)模型抽象到一個散列表里面,比如你的web系統(tǒng)中有一個用戶對象,不要為這個用戶的名稱,姓氏,郵箱,密碼設(shè)置單獨的key,而是應(yīng)該把這個用戶所有信息存儲到一張散列表中
Redis回收進程如何工作?
一個Client運行了新的命令,添加了新的數(shù)據(jù),Redis會檢查內(nèi)存使用情況,如果大于maxmemory的限制,則根據(jù)設(shè)定好的策略進行回收
Redis常用的使用場景
以上是Redis都有哪些面試題的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學(xué)習(xí)更多知識,歡迎關(guān)注創(chuàng)新互聯(lián)-成都網(wǎng)站建設(shè)公司行業(yè)資訊頻道!