redis持久化 Redis是一種記憶體型資料庫,一旦伺服器進程退出,資料庫的數據就會丟失, 為瞭解決這個問題,Redis提供了兩種持久化的方案,將記憶體中的數據保存到磁碟中,避免數據的丟失。 RDB持久化 redis提供了 持久化的功能, 在指定的時間間隔內生成數據集的時間點快照(point in t ...
redis持久化
Redis是一種記憶體型資料庫,一旦伺服器進程退出,資料庫的數據就會丟失,
為瞭解決這個問題,Redis提供了兩種持久化的方案,將記憶體中的數據保存到磁碟中,避免數據的丟失。
RDB持久化
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數據文件是二進位文件,人為的看不懂
redis持久化之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
主從同步
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,用哨兵自動選舉新主人
redis哨兵:
哨兵功能:
哨兵進行檢測,主從架構是否正常,如果主庫掛掉,哨兵會自動的修改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掛掉的資料庫,查看是否會被哨兵,添加進信息的主從集群
註意!!如果發現不成功,需刪掉所有的哨兵配置文件,從新來過
註意!!如果發現不成功,需刪掉所有的哨兵配置文件,從新來過
註意!!如果發現不成功,需刪掉所有的哨兵配置文件,從新來過