模擬redis災(zāi)難恢復(fù)(實(shí)驗(yàn))

目前通常的設(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)

成都seo排名網(wǎng)站優(yōu)化