好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

主頁 > 知識庫 > Linux下redis的持久化、主從同步與哨兵詳解

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

熱門標簽:百應電銷機器人靠譜嗎 菏澤crm外呼系統價格 遼寧電銷平臺外呼系統軟件 申請400電話號碼多少錢 營銷電銷機器人招商 物超所值的400電話申請 信陽銷售外呼系統招商 coreldraw地圖標注 如何在各種地圖標注自己的地址

1.0 redis持久化

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

1|1RDB持久化

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

它可以手動執行。

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

優點:速度快,適合做備份,主從復制就是基于RDB持久化功能實現

rdb通過在redis中使用save命令觸發 rdb

rdb配置參數:

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

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

save 900秒 1個修改類的操作

save 300秒 10個操作

save 60秒 10000個操作

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

3.重啟redis,數據不再丟失

4.rdb數據文件是二進制文件,人為的看不懂

1|2redis持久化之AOF

AOF(append-only log file)

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

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

優點:最大程序保證數據不丟

缺點:日志記錄非常大

配置方式

1.在配置文件中,添加aof參數

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

appendonly yes
appendfsync everysec

2.重啟redis數據庫,加載aof功能

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

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

4.登錄redis-cli,寫入數據,實時監聽aof文件信息

tail -f appendonly.aof

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

redis-cli -a redhat shutdown
redis-server /etc/redis.conf
redis-cli -a redhat

在不重啟redis的情況下,切換rdb數據到aof數據中

1.配置redis支持rdb持久化

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

127.0.0.1:6379> CONFIG set appendonly yes
OK
127.0.0.1:6379> CONFIG SET save ""
OK

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

tail -f appendonly.aof

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

編輯redis-6379.conf 添加如下參數

appendonly yes
appendfsync everysec

2|0主從同步

redis主從同步實現

1.準備三個redis數據庫,redis支持多實例

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

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

redis-6379.conf

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

redis-6380.conf

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

redis-6381.conf

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

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

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

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

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,準備好了三個數據庫實例,啟動三個數據庫實例

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

3,準備三個哨兵,開始監控主從架構

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

redis-26379.conf

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

redis-26380.conf

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

redis-26381.conf

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

4,啟動三個哨兵實例

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

檢查哨兵狀態是否正常

只有發現如下信息,與下面一致,即為正常

redis-cli -p 26379 info sentinel

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

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

1.干掉6379的redis數據庫

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

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

注意!!如果發現不成功,需刪掉所有的哨兵配置文件,從新來過
注意!!如果發現不成功,需刪掉所有的哨兵配置文件,從新來過
注意!!如果發現不成功,需刪掉所有的哨兵配置文件,從新來過

總結

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

標簽:江門 湖北 廈門 江西 內江 泰安 瀘州 玉樹

巨人網絡通訊聲明:本文標題《Linux下redis的持久化、主從同步與哨兵詳解》,本文關鍵詞  Linux,下,redis,的,持久化,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《Linux下redis的持久化、主從同步與哨兵詳解》相關的同類信息!
  • 本頁收集關于Linux下redis的持久化、主從同步與哨兵詳解的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 男生把脱了内裤露出j视频| 成人高清视频在线观看大全| 51国产偷自视频区视频| 亚洲精品主播一区二区三区| ??羞羞漫画网站入口| 99久久精品国产自免费| 西瓜视频官网| 国产一级大片| 一级a婬片试看3o分钟囗交| 色翁荡息又大又硬又粗又爽小玲 | 亚洲AV天堂Av在线网唯爱网| 很黄很污的小说| 日本高清免费h色视频在线观看| 日韩欧美AV乱码夜夜摸| 国产精品久久久久久小说| 韩国黄色一级片| 被先生调教训诫打屁股| 高清性色生活片,| 抓老师的两只兔子| 长篇yin乱荡合集小说| 亚洲精品乱码97久久久久久丝袜| 好湿?好紧?好多水含羞草| 国产私拍福利精品视频51Ⅴv| 动漫美女被奸| 国产AV精品亚洲AV蟹美脚| 夜夜嗨老熟女AV视频| 久久夜夜视频| 中文字幕精品亚洲无线码二区| 久r爱999久亚洲AV色| 女人被男人躁得好爽免费文| 国产乱人妻精品秘?入口| 少妇婬荡呻吟揉捏奶头视频| 秋霞理论一级在线观看手机版| a一级毛片久久久久久精品| 17c在线精品无码秘?入口| 乖乖快穿| 天天插天天狠| 老师你太大我坐不下h| 中国美女hdxxxxx| 摸胸吃下面| 欧美人人|