目前通常的設(shè)計(jì)思路:
創(chuàng)新互聯(lián)專注于企業(yè)營(yíng)銷型網(wǎng)站建設(shè)、網(wǎng)站重做改版、卓尼網(wǎng)站定制設(shè)計(jì)、自適應(yīng)品牌網(wǎng)站建設(shè)、html5、商城網(wǎng)站開發(fā)、集團(tuán)公司官網(wǎng)建設(shè)、成都外貿(mào)網(wǎng)站建設(shè)、高端網(wǎng)站制作、響應(yīng)式網(wǎng)頁(yè)設(shè)計(jì)等建站業(yè)務(wù),價(jià)格優(yōu)惠性價(jià)比高,為卓尼等各大城市提供網(wǎng)站開發(fā)制作服務(wù)。
????利用replication機(jī)制來(lái)彌補(bǔ)aof、snapshot性能上的不足,達(dá)到了數(shù)據(jù)可持久化。
????即master上RDB和AOF都不開啟,來(lái)保證master的讀寫性能,
????而slave上則同時(shí)開啟RDB和AOF來(lái)進(jìn)行持久化,保證數(shù)據(jù)的安全性。
????
? ? 如果數(shù)據(jù)要做持久化,又想保證穩(wěn)定性,建議留一半的物理內(nèi)存。
? ? 因?yàn)樵谶M(jìn)行snapshot時(shí),fork出來(lái)進(jìn)行dump操作的子進(jìn)程會(huì)占用與父進(jìn)程一樣的內(nèi)存,
? ? 真正的copy-on-write,對(duì)性能的影響和內(nèi)存的耗用都是比較大的。
環(huán)境描述:
? ? master:192.168.2.100 ? ?不開啟RDB和AOF
? ? slave:192.168.2.200 ? ?開啟RDB和AOF
配置信息:
? ? master:
? ? ? ? # vim etc/redis.conf
? ? ? ? ? ? #save 600 5 ? ? ? ? ? //禁用RDB
? ? ? ? ? ? appendonly no ? ? ? //禁用AOF
? ? ? ? ? ? requirepass 123456 ? ? ? ?//指定驗(yàn)證密碼
? ? slave:
? ? ? ? # vim etc/redis.conf
? ? ? ? ? ? save 600 5 ? ? ? ? ? //開啟RDB
? ? ? ? ? ? dbfilename "dump_6379.rdb" ? ? ? ? //RDB文件
? ? ? ? ? ? dir "/usr/local/redis-3.0.6-6379" ? ? ? ? ? //RDB文件路徑
? ? ? ? ? ? appendonly yes ? ? ?//開啟AOF
? ? ? ? ? ? appendfilename "appendonly.aof" ? ? ? ?//指定AOF文件
? ? ? ? ? ? appendfsync everysec ? ? ? ? ? ? ? ?//每秒強(qiáng)制寫入磁盤一次
? ? ? ? ? ? no-appendfsync-on-rewrite no ? ? ? ?//在日志重寫時(shí),不進(jìn)行命令追加操作
? ? ? ? ? ? auto-aof-rewrite-percentage 100 ? ? ? ? ? ?//當(dāng)前AOF超過(guò)上一次AOF大小100%時(shí)重寫
? ? ? ? ? ? auto-aof-rewrite-min-size 64mb ? ? ? ? ? //日志重寫最小值
? ? ? ? ? ? slaveof 192.168.2.100 6379 ? ? ? ? ?//指定主庫(kù)IP和端口
? ? ? ? ? ? masterauth 123456 ? ? ? ? ?//指定主庫(kù)登錄密碼
啟動(dòng)redis:
? ? master:# redis-server etc/redis.conf
? ? slave:# redis-server etc/redis.conf
master創(chuàng)建key:
? ? # redis-cli -a 123456
? ? ? ? 127.0.0.1:6379> info replication ? ? ? ? //查看主從關(guān)系是否正確
? ? ? ? 127.0.0.1:6379> keys * ? ? ? ? ? ? ? //此時(shí),master安裝目錄下是沒(méi)有RDB文件的
? ? ? ? (empty list or set)
? ? ? ? 127.0.0.1:6379> set name zhagnsan ? ? ? //創(chuàng)建3個(gè)key
? ? ? ? OK
? ? ? ? 127.0.0.1:6379> set age 26
? ? ? ? OK
? ? ? ? 127.0.0.1:6379> set home beijing
? ? ? ? OK
slave檢查同步情況:
? ? # redis-cli?
? ? ? ? 127.0.0.1:6379> keys * ? ? ? ? ? ?//數(shù)據(jù)已同步
? ? ? ? 1) "age"
? ? ? ? 2) "home"
? ? ? ? 3) "name"
模擬master故障:
? ? # ps -ef |grep redis
? ? ? ? root ? ? 126472 ? ? ?1 ?0 21:58 ? ? ? ? ?00:00:02 redis-server *:6379
? ? ? ? root ? ? 127714 ? 2844 ?0 22:29 pts/0 ? ?00:00:00 grep --color=auto redis
? ? # kill -9 126472
? ? # rm -rf dump_6379.rdb
slave查看主從狀態(tài):
? ? # redis-cli?
? ? ? ? 127.0.0.1:6379> info replication
? ? ? ? # Replication
? ? ? ? role:slave
? ? ? ? master_host:192.168.2.100
? ? ? ? master_port:6379
? ? ? ? master_link_status:down ? ? ? ? ? ? ? ?//我們看到master已經(jīng)不可訪問(wèn)了,slave正常
? ? ? ? master_last_io_seconds_ago:-1
? ? ? ? ... ...?
災(zāi)難恢復(fù):
? ? 1、取消slave的同步狀態(tài)
? ? ? ? 避免master未完成數(shù)據(jù)恢復(fù)就重啟,導(dǎo)致覆蓋掉slave上的數(shù)據(jù),最終數(shù)據(jù)丟失。
? ? ? ? 127.0.0.1:6379> SLAVEOF no one ? ? ?//動(dòng)態(tài)修改配置文件,將slavof設(shè)置為no
? ? ? ? OK
? ? ? ? 127.0.0.1:6379> info repolication ? ? ? ?//查看主從信息,已經(jīng)沒(méi)有了
? ? ? ? 127.0.0.1:6379>?
? ? ? ??
? ? 2、啟動(dòng)master的redis,確認(rèn)數(shù)據(jù)不存在(這步可以忽略,我只是想確認(rèn)下有沒(méi)有數(shù)據(jù))
? ? ? ? # redis-server etc/redis.conf
? ? ? ? # redis-cli -a 123456
? ? ? ? ? ? 127.0.0.1:6379> keys *
? ? ? ? ? ? ?(empty list or set)
? ? ? ? # ps -ef |grep redis
? ? ? ? ? ? root ? ? 128031 ? ? ?1 ?0 22:45 ? ? ? ? ?00:00:00 redis-server *:6379
? ? ? ? ? ? root ? ? 128050 ? 2844 ?0 22:46 pts/0 ? ?00:00:00 grep --color=auto redis
? ? ? ? # kill -9 128031 ? ? ? ? ? ? ? ? //再次異常關(guān)閉redis
? ? ? ? # rm -rf dump_6379.rdb ? ?//再次刪除RDB文件
? ? 3、拷貝RDB文件和AOF文件給master
? ? ? ? # scp dump_6379.rdb 192.168.2.100:/usr/local/redis-3.0.6-6379/
? ? ? ? # scp appendonly.aof 192.168.2.100:/usr/local/redis-3.0.6-6379/
? ? ? ??
? ? 4、master開啟RDB、開啟AOF
? ? ? ? # vim etc/redis.conf
? ? ? ? ? ? save 600 5 ? ? ? ? ? //開啟RDB
? ? ? ? ? ? dbfilename "dump_6379.rdb" ? ? ? ? //RDB文件
? ? ? ? ? ? dir "/usr/local/redis-3.0.6-6379" ? ? ? ? ? //RDB文件路徑
? ? ? ? ? ? appendonly yes ? ? ?//開啟AOF
? ? ? ? ? ? appendfilename "appendonly.aof" ? ? ? ?//指定AOF文件
? ? ? ? ? ? ... ...
? ? ? ? ? ??
? ? 5、master啟動(dòng)redis,查看庫(kù),數(shù)據(jù)已恢復(fù)
? ? ? ? # redis-server etc/redis.conf
? ? ? ? # redis-cli -a 123456
? ? ? ? ? ? 127.0.0.1:6379> keys *
? ? ? ? ? ? 1) "home"
? ? ? ? ? ? 2) "name"
? ? ? ? ? ? 3) "age"
? ? ? ? ? ??
? ? 6、master數(shù)據(jù)恢復(fù)后,需要關(guān)閉RDB和AOF,來(lái)保證自身的讀寫性能。
? ? ? ? 但是RDB文件和AOF文件要保留(不能恢復(fù)數(shù)據(jù)后給刪除了)
? ? ? ? 雖然RDB文件和AOF文件存在,但大小不會(huì)增加,依然只是salve的AOF文件增加。
? ? ? ? # kill [redis PID] ? ? ? ? ? ? ? //關(guān)閉redis ? ? ? ?
? ? ? ? # vim etc/redis.conf ? ? ? ?//關(guān)閉RDB和AOF
? ? ? ? ? ?#save 600 5
? ? ? ? ? ?appendonly no
? ? ? ? # redis-server etc/redis.conf ? ?//啟動(dòng)redis
? ? ? ? # redis-cli -a 123456
? ? ? ? ? ?127.0.0.1:6379> keys * ? ? ? //關(guān)閉RDB和AOF功能,庫(kù)中的數(shù)據(jù)依然存在
? ? ? ? ? ? 1) "home"
? ? ? ? ? ? 2) "name"
? ? ? ? ? ? 3) "age"
? ? ? ??
? ? 7、slave開啟同步狀態(tài)
? ? ? ? 127.0.0.1:6379> SLAVEOF 192.168.2.100 6379 ? ? ? ? ? //開啟同步狀態(tài)
? ? ? ? OK
? ? ? ? 127.0.0.1:6379> info replication
? ? ? ? # Replication
? ? ? ? role:slave
? ? ? ? master_host:192.168.2.100
? ? ? ? master_port:6379
? ? ? ? master_link_status:up ? ? ? ? ? ? ? ?//master可以正常訪問(wèn)了
? ? ? ? master_last_io_seconds_ago:5
? ? ? ? master_sync_in_progress:0
? ? ? ? ... ...
? ? 8、master創(chuàng)建key
? ? ? ? 127.0.0.1:6379> set abc 123 ? ? ?//新增一個(gè)key
? ? ? ? OK
? ? ? ? 127.0.0.1:6379> keys *
? ? ? ? 1) "abc"
? ? ? ? 2) "home"
? ? ? ? 3) "name"
? ? ? ? 4) "age"
? ? ? ??
? ? 9、slave查看同步情況
? ? ? ? 127.0.0.1:6379> keys *
? ? ? ? 1) "abc"
? ? ? ? 2) "age"
? ? ? ? 3) "home"
? ? ? ? 4) "name"
? ? ? ??
總結(jié):
? ? 在此次恢復(fù)的過(guò)程中,我們同時(shí)使用了AOF和RDB文件,那么到底是哪個(gè)文件完成了恢復(fù)呢?
? ? ? ? 1、如果只配置了RDB,啟動(dòng)時(shí)加載的是RDB文件;
? ? ? ? 2、如果只配置了AOF,啟動(dòng)時(shí)加載的是AOF文件;
? ? ? ? 3、如果同時(shí)配置了RDB和AOF,由于AOF優(yōu)先級(jí)高于RDB,所以使用的是AOF文件。
? ? ? ??
? ? 而且,AOF文件的數(shù)據(jù)完整性要高于RDB文件,因?yàn)镽DB是按照周期性策略進(jìn)行保存的。
? ? 如果在下個(gè)周期來(lái)臨前故障,那么將丟失上個(gè)周期到故障點(diǎn)的數(shù)據(jù)。
本文名稱:模擬redis災(zāi)難恢復(fù)(實(shí)驗(yàn))
鏈接地址:http://muchs.cn/article18/jehjdp.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供App設(shè)計(jì)、關(guān)鍵詞優(yōu)化、網(wǎng)頁(yè)設(shè)計(jì)公司、外貿(mào)建站、面包屑導(dǎo)航、網(wǎ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í)需注明來(lái)源: 創(chuàng)新互聯(lián)