麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 服務器 > Linux服務器 > 正文

Linux下redis的持久化、主從同步與哨兵詳解

2024-09-05 23:05:32
字體:
來源:轉載
供稿:網友

1.0 redis持久化

Redis是一種內存型數(shù)據(jù)庫,一旦服務器進程退出,數(shù)據(jù)庫的數(shù)據(jù)就會丟失,為了解決這個問題,Redis提供了兩種持久化的方案,將內存中的數(shù)據(jù)保存到磁盤中,避免數(shù)據(jù)的丟失。

1|1RDB持久化

redis提供了RDB持久化的功能,在指定的時間間隔內生成數(shù)據(jù)集的時間點快照(point-in-time snapshot)這個功能可以將redis在內存中的的狀態(tài)保存到硬盤中,RDB持久化產生的RDB文件是一個經過壓縮的二進制文件,這個文件被保存在硬盤中,redis可以通過這個文件還原數(shù)據(jù)庫當時的狀態(tài)。

它可以手動執(zhí)行。

也可以在redis.conf中配置,定期執(zhí)行。

優(yōu)點:速度快,適合做備份,主從復制就是基于RDB持久化功能實現(xiàn)

rdb通過在redis中使用save命令觸發(fā) rdb

rdb配置參數(shù):

port 6379 daemonize yes pidfile /data/6379/redis.pidloglevel notice logfile "/data/6379/redis.log"dir /data/6379 protected-mode yes dbfilename dbmp.rdbsave 900 1save 300 10 save 60 10000

每過900秒 有1個操作就進行持久化

save 900秒 1個修改類的操作

save 300秒 10個操作

save 60秒 10000個操作

2.觸發(fā)rdb持久化,也可以手動save命令即可,生成 dump.rdb持久化文件

3.重啟redis,數(shù)據(jù)不再丟失

4.rdb數(shù)據(jù)文件是二進制文件,人為的看不懂

1|2redis持久化之AOF

AOF(append-only log file)

記錄服務器執(zhí)行的所有變更操作命令(例如set del等),并在服務器啟動時,通過重新執(zhí)行這些命令來還原數(shù)據(jù)集

AOF 文件中的命令全部以redis協(xié)議的格式保存,新命令追加到文件末尾。

優(yōu)點:最大程序保證數(shù)據(jù)不丟

缺點:日志記錄非常大

配置方式

1.在配置文件中,添加aof參數(shù)

在redis-6379.conf中添加參數(shù),開啟aof功能

appendonly yesappendfsync everysec

2.重啟redis數(shù)據(jù)庫,加載aof功能

3.檢查redis數(shù)據(jù)目錄/data/6379/是否產生了aof文件

[root@web02 6379]# lsappendonly.aof dbmp.rdb redis.log

4.登錄redis-cli,寫入數(shù)據(jù),實時監(jiān)聽aof文件信息

tail -f appendonly.aof

5.設置新key,檢查aof信息,然后關閉redis,檢查數(shù)據(jù)是否持久化

redis-cli -a redhat shutdownredis-server /etc/redis.confredis-cli -a redhat

在不重啟redis的情況下,切換rdb數(shù)據(jù)到aof數(shù)據(jù)中

1.配置redis支持rdb持久化

2.啟動redis客戶端,通過命令,臨時切換到aof模式

127.0.0.1:6379> CONFIG set appendonly yesOK127.0.0.1:6379> CONFIG SET save ""OK

3.檢查此時的數(shù)據(jù)持久化方式是rdb,還是aof,檢查appendonly.aof文件,數(shù)據(jù)變動

tail -f appendonly.aof

4.此時aof還未永久生效,寫入參數(shù)到配置文件

編輯redis-6379.conf 添加如下參數(shù)

appendonly yes
appendfsync everysec

2|0主從同步

redis主從同步實現(xiàn)

1.準備三個redis數(shù)據(jù)庫,redis支持多實例

三個配置文件,僅僅是端口的不同

在三個配置文件中,添加主從同步的參數(shù)

redis-6379.conf

port 6379 daemonize yes pidfile /data/6379/redis.pidloglevel notice logfile "/data/6379/redis.log"dir /data/6379 protected-mode yes dbfilename dbmp.rdbsave 900 1save 300 10 save 60 10000

redis-6380.conf

port 6380 daemonize yes pidfile /data/6380/redis.pidloglevel notice logfile "/data/6380/redis.log"dir /data/6380 protected-mode yes dbfilename dbmp.rdbsave 900 1save 300 10 save 60 10000slaveof 127.0.0.1 6379

redis-6381.conf

port 6381 daemonize yes pidfile /data/6381/redis.pidloglevel notice logfile "/data/6381/redis.log"dir /data/6381 protected-mode yes dbfilename dbmp.rdbsave 900 1save 300 10 save 60 10000slaveof 127.0.0.1 6379

2.啟動三個數(shù)據(jù)庫實例,查看主從同步身份

redis-cli -p 6379 info replication redis-cli -p 6380 info replication redis-cli -p 6381 info replication 

3:確保查看信息如下 并且檢查是否同步

Linux,redis,持久化,主從同步,哨兵

Linux,redis,持久化,主從同步,哨兵

4.如果我主庫掛了怎么辦??

解決方案:

1.手動切換主從身份,選舉一個新的主庫

1.干掉6379主庫
2.在6380上關閉自己的slave身份
slaveof no one
3.在6381上給與新的主人身份
salveof 127.0.0.1 6380
4.修改完畢,還得修改配置文件,永久生效

2,用哨兵自動選舉新主人

2|1redis哨兵:

哨兵功能:

  哨兵進行檢測,主從架構是否正常,如果主庫掛掉,哨兵會自動的修改redis.conf,進行添加/刪除 slaveof 指令

redis哨兵安裝配置:

1.準備三個redis實例,一主兩從

詳見上面redis主從配置

2,準備好了三個數(shù)據(jù)庫實例,啟動三個數(shù)據(jù)庫實例

redis-server redis-6379.confredis-server redis-6380.confredis-server redis-6381.conf

3,準備三個哨兵,開始監(jiān)控主從架構

準備三個配置文件,哨兵文件

redis-26379.conf

port 26379 dir /var/redis/data/logfile "26379.log"sentinel monitor sbmaster 127.0.0.1 6379 2sentinel down-after-milliseconds qsmaster 30000sentinel parallel-syncs sbmaster 1sentinel failover-timeout sbmaster 180000daemonize yes 

redis-26380.conf

port 26380 dir /var/redis/data/logfile "26380.log"sentinel monitor sbmaster 127.0.0.1 6379 2sentinel down-after-milliseconds qsmaster 30000sentinel parallel-syncs sbmaster 1sentinel failover-timeout sbmaster 180000daemonize yes

redis-26381.conf

port 26381 dir /var/redis/data/logfile "26381.log"sentinel monitor sbmaster 127.0.0.1 6379 2sentinel down-after-milliseconds sbmaster 30000sentinel parallel-syncs sbmaster 1sentinel failover-timeout sbmaster 180000daemonize yes 

4,啟動三個哨兵實例

redis-sentinel redis-26380.conf redis-sentinel redis-26379.conf redis-sentinel redis-26381.conf 

檢查哨兵狀態(tài)是否正常

只有發(fā)現(xiàn)如下信息,與下面一致,即為正常

redis-cli -p 26379 info sentinel

# Sentinelsentinel_masters:1sentinel_tilt:0sentinel_running_scripts:0sentinel_scripts_queue_length:0sentinel_simulate_failure_flags:0master0:name=sbmaster,status=ok,address=127.0.0.1:6380,slaves=2,sentinels=3

5,進行哨兵自動主從切換

1.干掉6379的redis數(shù)據(jù)庫

2.查看6380和6381的身份信息,是否自動的進行主從切換(需等待30秒才會切換)

3.手動啟動6379掛掉的數(shù)據(jù)庫,查看是否會被哨兵,添加進信息的主從集群

注意!!如果發(fā)現(xiàn)不成功,需刪掉所有的哨兵配置文件,從新來過
注意!!如果發(fā)現(xiàn)不成功,需刪掉所有的哨兵配置文件,從新來過
注意!!如果發(fā)現(xiàn)不成功,需刪掉所有的哨兵配置文件,從新來過

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對VEVB武林網的支持。


注:相關教程知識閱讀請移步到服務器教程頻道。
發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 色视频在线播放 | 成人aaaa免费全部观看 | 欧美激情猛片xxxⅹ大3 | 最近中文字幕一区二区 | 国产精品成人av片免费看最爱 | 在线观看国产 | 男女羞羞的视频 | 国产精品久久久久无码av | 97超级碰碰人国产在线观看 | 国产精品一区二av18款 | 久久激情免费视频 | 91a在线观看 | 亚洲精品a级 | 精品国产一区二区三 | 暴力肉体进入hdxxxx古装 | 国产精品一区二区三区在线 | 蜜桃免费在线 | 欧美精品一区二区久久久 | 青青草成人av | 国产成人综合在线 | 日本不卡一区二区三区在线观看 | a免费视频 | 女人裸体让男人桶全过程 | 国产xxxx免费 | 激情久久精品 | 成人在线免费观看视频 | 九草在线 | 亚洲人成在线播放 | 亚洲第一成人久久网站 | 蜜桃av网 | 欧美成年人视频在线观看 | 日韩一级毛毛片 | 91香蕉国产亚洲一区二区三区 | 国产一级小视频 | av久草 | 99爱福利视频在线观看 | 九九热九九爱 | 成人网在线观看 | 中文字幕在线亚洲 | 日本在线视频二区 | 亚洲精品久久久久www |