中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

模擬redis災難恢復(實驗)

發布時間:2020-08-03 03:21:56 來源:網絡 閱讀:2273 作者:張德帥ya 欄目:數據庫

目前通常的設計思路:

????利用replication機制來彌補aof、snapshot性能上的不足,達到了數據可持久化。

????即master上RDB和AOF都不開啟,來保證master的讀寫性能,

????而slave上則同時開啟RDB和AOF來進行持久化,保證數據的安全性。

????

? ? 如果數據要做持久化,又想保證穩定性,建議留一半的物理內存。

? ? 因為在進行snapshot時,fork出來進行dump操作的子進程會占用與父進程一樣的內存,

? ? 真正的copy-on-write,對性能的影響和內存的耗用都是比較大的。


環境描述:

? ? 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 ? ? ? ?//指定驗證密碼

? ? 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 ? ? ? ? ? ? ? ?//每秒強制寫入磁盤一次

? ? ? ? ? ? no-appendfsync-on-rewrite no ? ? ? ?//在日志重寫時,不進行命令追加操作

? ? ? ? ? ? auto-aof-rewrite-percentage 100 ? ? ? ? ? ?//當前AOF超過上一次AOF大小100%時重寫

? ? ? ? ? ? auto-aof-rewrite-min-size 64mb ? ? ? ? ? //日志重寫最小值

? ? ? ? ? ? slaveof 192.168.2.100 6379 ? ? ? ? ?//指定主庫IP和端口

? ? ? ? ? ? masterauth 123456 ? ? ? ? ?//指定主庫登錄密碼


啟動redis:

? ? master:# redis-server etc/redis.conf

? ? slave:# redis-server etc/redis.conf


master創建key:

? ? # redis-cli -a 123456

? ? ? ? 127.0.0.1:6379> info replication ? ? ? ? //查看主從關系是否正確

? ? ? ? 127.0.0.1:6379> keys * ? ? ? ? ? ? ? //此時,master安裝目錄下是沒有RDB文件的

? ? ? ? (empty list or set)

? ? ? ? 127.0.0.1:6379> set name zhagnsan ? ? ? //創建3個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 * ? ? ? ? ? ?//數據已同步

? ? ? ? 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查看主從狀態:

? ? # 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已經不可訪問了,slave正常

? ? ? ? master_last_io_seconds_ago:-1

? ? ? ? ... ...?


災難恢復:

? ? 1、取消slave的同步狀態

? ? ? ? 避免master未完成數據恢復就重啟,導致覆蓋掉slave上的數據,最終數據丟失。

? ? ? ? 127.0.0.1:6379> SLAVEOF no one ? ? ?//動態修改配置文件,將slavof設置為no

? ? ? ? OK

? ? ? ? 127.0.0.1:6379> info repolication ? ? ? ?//查看主從信息,已經沒有了

? ? ? ? 127.0.0.1:6379>?

? ? ? ??

? ? 2、啟動master的redis,確認數據不存在(這步可以忽略,我只是想確認下有沒有數據)

? ? ? ? # 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 ? ? ? ? ? ? ? ? //再次異常關閉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啟動redis,查看庫,數據已恢復

? ? ? ? # redis-server etc/redis.conf

? ? ? ? # redis-cli -a 123456

? ? ? ? ? ? 127.0.0.1:6379> keys *

? ? ? ? ? ? 1) "home"

? ? ? ? ? ? 2) "name"

? ? ? ? ? ? 3) "age"

? ? ? ? ? ??

? ? 6、master數據恢復后,需要關閉RDB和AOF,來保證自身的讀寫性能。

? ? ? ? 但是RDB文件和AOF文件要保留(不能恢復數據后給刪除了)

? ? ? ? 雖然RDB文件和AOF文件存在,但大小不會增加,依然只是salve的AOF文件增加。

? ? ? ? # kill [redis PID] ? ? ? ? ? ? ? //關閉redis ? ? ? ?

? ? ? ? # vim etc/redis.conf ? ? ? ?//關閉RDB和AOF

? ? ? ? ? ?#save 600 5

? ? ? ? ? ?appendonly no

? ? ? ? # redis-server etc/redis.conf ? ?//啟動redis

? ? ? ? # redis-cli -a 123456

? ? ? ? ? ?127.0.0.1:6379> keys * ? ? ? //關閉RDB和AOF功能,庫中的數據依然存在

? ? ? ? ? ? 1) "home"

? ? ? ? ? ? 2) "name"

? ? ? ? ? ? 3) "age"

? ? ? ??

? ? 7、slave開啟同步狀態

? ? ? ? 127.0.0.1:6379> SLAVEOF 192.168.2.100 6379 ? ? ? ? ? //開啟同步狀態

? ? ? ? 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可以正常訪問了

? ? ? ? master_last_io_seconds_ago:5

? ? ? ? master_sync_in_progress:0

? ? ? ? ... ...


? ? 8、master創建key

? ? ? ? 127.0.0.1:6379> set abc 123 ? ? ?//新增一個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"

? ? ? ??

總結:

? ? 在此次恢復的過程中,我們同時使用了AOF和RDB文件,那么到底是哪個文件完成了恢復呢?

? ? ? ? 1、如果只配置了RDB,啟動時加載的是RDB文件;

? ? ? ? 2、如果只配置了AOF,啟動時加載的是AOF文件;

? ? ? ? 3、如果同時配置了RDB和AOF,由于AOF優先級高于RDB,所以使用的是AOF文件。

? ? ? ??

? ? 而且,AOF文件的數據完整性要高于RDB文件,因為RDB是按照周期性策略進行保存的。

? ? 如果在下個周期來臨前故障,那么將丟失上個周期到故障點的數據。




向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

渭南市| 区。| 松滋市| 剑阁县| 泾川县| 井陉县| 黑龙江省| 烟台市| 个旧市| 龙山县| 香港| 渝中区| 民丰县| 花垣县| 封开县| 新平| 天镇县| 平泉县| 疏勒县| 阿拉善右旗| 南安市| 仙居县| 辉县市| 兰坪| 安庆市| 博白县| 乌兰浩特市| 杂多县| 湖北省| 图木舒克市| 遂平县| 石嘴山市| 房山区| 韶山市| 平泉县| 阳春市| 鄯善县| 施秉县| 通河县| 滦平县| 南投市|