這篇文章主要介紹“redis高可用和持久化概述”,在日常操作中,相信很多人在Redis高可用和持久化概述問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”Redis高可用和持久化概述”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!
成都創(chuàng)新互聯(lián)公司是一家集網(wǎng)站建設,文峰企業(yè)網(wǎng)站建設,文峰品牌網(wǎng)站建設,網(wǎng)站定制,文峰網(wǎng)站建設報價,網(wǎng)絡營銷,網(wǎng)絡優(yōu)化,文峰網(wǎng)站推廣為一體的創(chuàng)新建站企業(yè),幫助傳統(tǒng)企業(yè)提升企業(yè)形象加強企業(yè)競爭力。可充分滿足這一群體相比中小企業(yè)更為豐富、高端、多元的互聯(lián)網(wǎng)需求。同時我們時刻保持專業(yè)、時尚、前沿,時刻以成就客戶成長自我,堅持不斷學習、思考、沉淀、凈化自己,讓我們?yōu)楦嗟钠髽I(yè)打造出實用型網(wǎng)站。
持久化:
持久化是最簡單的高可用方法(有時甚至不被歸為高可用手段),主要作用是數(shù)據(jù)備份,即將數(shù)據(jù)存儲在硬盤,保證數(shù)據(jù)不會因進程退出而丟失。
復制:
復制是高可用Redis的基礎,哨兵和集群都是在復制的基礎上實現(xiàn)高可用的。復制主要實現(xiàn)了數(shù)據(jù)的多機備份,以及對于讀操作的負載均衡和簡單的故障恢復。
缺陷:故障恢復無法自動化,寫操作無法負載均衡,存儲能力受到單機的限制。
哨兵:
在復制的基礎上,哨兵實現(xiàn)了自動化的故障恢復。
缺陷:寫操作無法負載均衡;存儲能力收到單機限制。
集群:
通過集群,Redis解決了操作無法負載均衡,以及存儲能力收到單機限制的問題,實現(xiàn)了較為完善的高可用解決方案。
持久化的功能:Redis是內存數(shù)據(jù)庫,數(shù)據(jù)都是存儲在內存中。
Redis的持久化分為RDB和AOF持久化:
前者是將數(shù)據(jù)保存到硬盤。
后者是將每次執(zhí)行的寫命令保存到硬盤。
RDB持久化
RDB持久化是將當前進程中的數(shù)據(jù)生成快照保存到硬盤中(因此也叫做快照持久化),保存的文件后綴是RDB;
當Redis重新啟動時,可以讀取快照文件恢復數(shù)據(jù)。
手動觸發(fā):
save命令和bgsave命令都可以生成RDB文件。
save命令會阻塞Redis服務進程,直到RDB文件創(chuàng)建完畢為止,在Redis服務器阻塞期間,服務器不能執(zhí)行任何命令請求。
bgsave命令會創(chuàng)建一個子進程,由子進程來創(chuàng)建RDB文件,父進程(即Redis主進程)繼續(xù)處理請求。bgsave命令執(zhí)行過程中,只有fork(ork了進程,子進程中的redis連接沒法用了,要重連)子進程會阻塞服務器,而對于save命令,整個過程都會阻塞服務器。
在自動觸發(fā)RDB持久化時,Redis也會使用bgsave而不是save來進行持久化;下面介紹自動觸發(fā)RDB持久化條件。
自動觸發(fā):
最常見的情況是在配置文件中通過savemn,指定m秒內發(fā)生了n次變化時,會觸發(fā)bgsave。
到此,關于“Redis高可用和持久化概述”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續(xù)學習更多相關知識,請繼續(xù)關注創(chuàng)新互聯(lián)網(wǎng)站,小編會繼續(xù)努力為大家?guī)砀鄬嵱玫奈恼拢?/p>
本文名稱:Redis高可用和持久化概述
當前地址:http://weahome.cn/article/pscdsc.html