這篇文章給大家分享的是有關(guān)redis持久化是什么意思的內(nèi)容。小編覺得挺實(shí)用的,因此分享給大家做個(gè)參考。一起跟隨小編過來看看吧。
創(chuàng)新互聯(lián)主要企業(yè)基礎(chǔ)官網(wǎng)建設(shè),電商平臺(tái)建設(shè),移動(dòng)手機(jī)平臺(tái),成都小程序開發(fā)等一系列專為中小企業(yè)定制網(wǎng)站設(shè)計(jì)產(chǎn)品體系;應(yīng)對(duì)中小企業(yè)在互聯(lián)網(wǎng)運(yùn)營(yíng)的各種問題,為中小企業(yè)在互聯(lián)網(wǎng)的運(yùn)營(yíng)中保駕護(hù)航。
centos7.0 redis4.0 redis存放目錄:/usr/local/redis redis.conf存放目錄:/usr/local/redis/data
redis的所有數(shù)據(jù)都是保存在內(nèi)存中,redis崩掉數(shù)據(jù)會(huì)丟失。redis持久化就是把數(shù)據(jù)保存在磁盤上。利用永久性存儲(chǔ)介質(zhì)將數(shù)據(jù)進(jìn)程保存,在特定的時(shí)間將保存的數(shù)據(jù)進(jìn)行恢復(fù)的工作機(jī)制稱為持久化。
持久化過程保存的是什么呢?
第一種快照形式,存儲(chǔ)數(shù)據(jù)結(jié)果,關(guān)注點(diǎn)在數(shù)據(jù),也就是下文會(huì)講到的RDB
第二種操作過程,存儲(chǔ)操作過程,存儲(chǔ)結(jié)構(gòu)復(fù)雜,關(guān)注點(diǎn)在數(shù)據(jù)的操作過程,也就是下文會(huì)講到的AOF
下圖是redis.conf的配置信息,在執(zhí)行完save后會(huì)生成一個(gè)dump.rdb的文件現(xiàn)在我們?cè)O(shè)置一個(gè)值,然后save一下,在/usr/local/redis/data下就會(huì)有一個(gè)dump6379.rdb的一個(gè)文件
其實(shí)這個(gè)數(shù)據(jù)恢復(fù)相對(duì)于其他關(guān)系型數(shù)據(jù)庫(kù)恢復(fù)基本就不用操作什么。只需要重新在啟動(dòng)就好了
此圖來源于網(wǎng)絡(luò)視頻。
save指令的執(zhí)行會(huì)阻塞當(dāng)前redis服務(wù)器,直到當(dāng)前RDB過程完為止,有可能會(huì)造成長(zhǎng)時(shí)間的阻塞。這個(gè)指令在工作過程中基本以被廢棄不在使用。會(huì)以bgsave全部代替
當(dāng)在redis執(zhí)行了bgsave后會(huì)直接返回一個(gè)Background saving started
這個(gè)時(shí)候我們?cè)诳匆幌氯罩疚募?,bgsave命令是針對(duì)save阻塞問題做的優(yōu)化
save 900 1
save 300 10
save 60 10000
stop-writes-on-bgsave-error yes
save 【時(shí)間】 【key改變數(shù)量】
也就是說在300秒有10個(gè)key值發(fā)生變化了,就會(huì)在后臺(tái)執(zhí)行bgsave
AOF持久化:以獨(dú)立日志的方式記錄每次寫命令,重啟時(shí)在重新執(zhí)行AOF文件中命令達(dá)到數(shù)據(jù)恢復(fù)的目的。與RDB相比可以簡(jiǎn)單描述為記錄數(shù)據(jù)產(chǎn)生的過程
AOF的主要作用是解決了數(shù)據(jù)持久化的實(shí)時(shí)性,目前已經(jīng)是redis持久化的主流方式
執(zhí)行一條redis命令
redis的AOF會(huì)把命令刷新緩沖區(qū)
然后根據(jù)一定的策略同步的到redis.conf配置的.aof文件中
appendonly yes|no
appendfsync always| everysec | no
然后使用重啟redis服務(wù),就可以在usr/local/redis/data目錄下可以看到appendonly.aof文件了
然后我們?cè)趓edis客戶端執(zhí)行一條命令,在來查看一下??梢钥吹綌?shù)據(jù)都會(huì)存入appendonly.aof這個(gè)文件中。
我們先看一個(gè)案例,我們重復(fù)設(shè)置了name這個(gè)key后,打開appendonly.aof文件查看,可以看到有三個(gè)操作,但是這三個(gè)操作我們都是修改的一個(gè)key??!我們只保存最后一個(gè)key不行嗎?帶著這個(gè)疑問,我們?cè)诶^續(xù)往下看
隨著命令不斷寫入AOF,文件會(huì)越來越大,為了解決這個(gè)問題,redis引入了AOF重寫機(jī)制壓縮文件體積。AOF文件重寫是將redis進(jìn)程內(nèi)的數(shù)據(jù)轉(zhuǎn)化為寫命令同步到新AOF文件的過程。簡(jiǎn)單說就是將對(duì)同一個(gè)數(shù)據(jù)的若干條命令執(zhí)行結(jié)果轉(zhuǎn)化為最終結(jié)果數(shù)據(jù)對(duì)應(yīng)指令的執(zhí)行記錄。
如在上邊我們執(zhí)行了三次 set name 指令,但是我們最終就只需要最后一次執(zhí)行的數(shù)據(jù)。也就是我們只需要最后一次執(zhí)行記錄即可。
hdel,srem
。 多次設(shè)置一個(gè)key值等lpush list a lpush lsit b lpush list c
可以轉(zhuǎn)化為lpush list a b c
。但是為了防止數(shù)據(jù)量過大造成客戶端緩沖區(qū)溢出,對(duì)list,set,hash,zset
類型每條指令最多寫入64個(gè)元素指令:bgrewriteaof
接著我們3-5的問題,我們?cè)诿钚袌?zhí)行bgrewriteaof指令然后查看appendonly.aof文件
當(dāng)執(zhí)行完后會(huì)發(fā)現(xiàn)文件變小了,文件里也就只有一條指令了
配置:auto-aof-rewrite-percentage 100 | auto-aof-rewrite-min-size 64mb
觸發(fā)對(duì)比參數(shù):aof_current_size | aof_base_size
當(dāng)aof_current_size > auto-aof-rewrite-min-size 64mb 會(huì)啟動(dòng)重寫
此圖來源于網(wǎng)絡(luò)
對(duì)數(shù)據(jù)非常敏感,建議使用默認(rèn)的AOF持久化方案
數(shù)據(jù)呈現(xiàn)階段有效性,建議使用RDB持久化方案
綜合對(duì)比
感謝各位的閱讀!關(guān)于Redis持久化是什么意思就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,讓大家可以學(xué)到更多知識(shí)。如果覺得文章不錯(cuò),可以把它分享出去讓更多的人看到吧!
文章題目:Redis持久化是什么意思
當(dāng)前路徑:http://chinadenli.net/article24/jioeje.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供標(biāo)簽優(yōu)化、移動(dòng)網(wǎng)站建設(shè)、網(wǎng)站改版、App設(shè)計(jì)、做網(wǎng)站、全網(wǎng)營(yíng)銷推廣
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)