Reids——持久化数据保存

1.Redis主从配置

主从概念

  • 一个master可以拥有多个slave,而一个slave又可以拥有多个slave,依次向下就好形成强大的多级服务器集群架构
  • master(主机)用来写数据,slave(从机)用来读数据,一般来说,网站的读写比例在10:1左右,通过主从配置可以实现读写分离。
  • master和slave都是一个redis的服务实例
    多级集群服务器基本架构
  • 主从配置
将主机的redis.conf配置里的Bind修改为主机ip或者本机ip
bind 0.0.0.0 或者bind 127.0.0.1

#开启主机服务(通过命令安装的reids版本)
redis-server redis.conf

  • 配置从redis
#复制redis.conf 命名为slave.conf
cp redis.conf slave.conf

#修改配置文件
vim slave.conf
bind 主机IP
#在Master下边添加
slave0f 主机ip 6379(端口)#redis3.0-4.0版本
replicaof 主机IP 6379#redis5.0版本
port 跟主机端口不一样最好大于1024(从机端口)
  • 开启服务
redis-cli (默认进入主机客户端)
redis-cli -p 从机端口 -h 主机IP

#在主机端口上可以进行读和写操作,在从机端口上只能进行读的操作,主机和从机数据同步

2.redis持久化

  • Redis的读写是在内存中,因此读取速度和性能十分快,但在内存中的数据会随着服务器的重启而丢失,为了保证数据不丢失,需要将内存中的数据保存到磁盘中,以便redis重启时能够从磁盘中恢复原有的数据,这整个过程就叫Redis持久化。
    在这里插入图片描述

持久化的三种方式

  1. 快照(RDB,Redis DataBase)将某时刻的状态即内存数据以二进制的形似写入磁盘里。可以很轻松的恢复到某个状态,例如ubuntun里可以随时恢复到虚拟机某一个时刻的。
  2. 文件追加方式(AOF,Append Only File),记录所有的操作命令,并以文本的形式追加到文件中。
  3. 混合持久化,混合持久化结合了RDB和AOF的优点,在写入的时候,先把当前的数据以RDB的形式写入文件的开头,再将后续的操作命令以AOF的格式存入文件,这样既能保证Redis重启时的速度,又能降低数据丢失的风险。

2.1持久化之——RDB

  • RDB(Redis DataBase):将某一时刻的内存快照(Snapshot),以二进制的方式写入磁盘的过程

  • RDB持久化触发方式有两种:1. 手动触发 2.自动触发

2.1.1. 手动触发

  • 手动触发操作:save 和bgsave,主要区别体现在:是否阻塞Redis主线程的执行。
  1. save命令:在客户端执行save命令就会触发持久化,但同时也会使得Redis处于阻塞状态,直到RDB持久化完成,才能响应其他客户端发来的命令,因此该命令一定要谨慎使用
    在这里插入图片描述
  2. bgsave(background save)命令:后台保存。它区别save的地方在于bgsave会fork()一个子进程来执行持久化,整个过程中,只有在fork()子进程时有短暂的阻塞,当子进程被创建以后,Redis的主进程就可以响应客户端的其他请求。

2.1.2自动触发

  1. save m n :指的是在M秒以内有n个键发生变化则自动触发持久化。在配置文件中可以找到相应的save参数。本质上Redis通过判断,一旦满足设置的触发条件,则自动执行一次bgsave命令。当有多个save配置时,满足任意一个条件都会触发持久化。
  2. FLUSHALL :清空数据库,当redis执行该命令以后,将触发自动持久化把RDB文件清空。在生产环境中谨慎使用

RDB自动触发参数说明:

# RDB 保存的条件
save 900 1
save 300 10
save 60 10000

# bgsave 失败之后,是否停止持久化数据到磁盘,yes 表示停止持久化,no 表示忽略错误继续写文件。
stop-writes-on-bgsave-error yes

# RDB 文件压缩
#表示是否开启RDB文件压缩,Redis会采用LZF算法进行压缩。如果不想消耗cpu性能来进行文件压缩,可以关闭该功能,缺点是需要更多的磁盘空间来保存文件。
rdbcompression yes

# 写入文件和读取文件时是否开启 RDB 文件检查,检查是否有无损坏,如果在启动是检查发现损坏,则停止启动。
rdbchecksum yes

# RDB 文件名
dbfilename dump.rdb

# RDB 文件目录
dir ./
  • 配置查询
    Redis中可以使用命令来查询当前配置参数。config get 命令

2.1.3 RDB优缺点

  • 优点占用内存小,适合做备份文件,更容易恢复Redis服务
    1. RDB内容为二进制数据,占用内存更小更紧凑,更适合作为备份文件。在灾难恢复时,可以更快的传输到 远程服务器进行Redis服务恢复
    2. RDB可以更大程度的提高Redis的运行速度,每次持久化时,都会创建一个fork子进程,不会阻塞主进程响应其他客户端的请求
    3. 与AOF文件相比,RDB文件可以更快的重启。
  • 缺点可能丢失一段时间的数据
    1. RDB只能保存某个时间间隔的数据,如果中途Redis服务意外终止了,这段时间的数据将会丢失。
    2. RDB需要经常使用fork()创建子进程才能使其持久化在磁盘上,若数据集很大时,fork()可能耗时严重,若数据集很大占用cpu全部性能可能导致Redis停止为客户端服务几毫秒等短暂时间 。

2.2持久化——AOF

  • 由于Redis使用RDB持久化可能会由于意外终止服务而导致丢失一部分最新数据。因此提出了另一种持久化方案AOF
  • AOF(Append Only File)中文是追加到文件中,因此AOF可以将Redis每个键值对的操作都记录到文件(appendonly.aof)中。

2.2.1查询和设置

  1. 查询AOF启动状态
    使用config get appendonly命令
    在这里插入图片描述第一行appendonly表示AOF文件的名称

  2. 开启AOF持久化-

  • Redis默认是关闭AOF持久化的,开启AOF持久化有两种方式
    1. 命令行启动AOF:使用config set appendonly yes命令
      在这里插入图片描述
      命令行启动优点:无需重启Redis服务。
      缺点:如果Redis服务重启,则命令行设置失效

    2. 配置文件启动AOF:Redis的配置文件为redis.conf,使用config get dir 可以获取Redis的根目录

127.0.0.1:6379> config get dir
1) "dir"
2) "/var/lib/redis"


#在配置文件中将appendonly 设置为yes即可,默认的是No处于关闭状态

配置文件启动AOF缺点:每次修改配置文件都要重启Redis服务才能生效。
优点:无论重启多少次Redis服务,配置文件中的配置信息都不会失效。

2.2.2触发持久化

  • AOF持久化开启也有两种触发方式:自动触发和手动触发
自动触发:策略触发和重写触发
  1. 满足AOF设置的策略触发
  • always:每条Redis操作命令都会写入磁盘,最多丢失一条数据
  • everysec:每秒钟写入一次磁盘,最多丢失疫苗的数据;(配置默认)
  • no:不设置写入磁盘的规则,根据当前操作系统来决定何时写入磁盘,Linux默认30秒写入一次数据到磁盘。

注意:通过在配置文件(redis.conf)里进行设置。

# 是否开启 AOF,yes 为开启,默认是关闭
appendonly no

# AOF 默认文件名
appendfilename "appendonly.aof"

# AOF 持久化策略配置
# appendfsync always
#appendfsync everysec
# appendfsync no
  1. AOF重写触发:由于AOF是通过记录每一次的操作命令来持久化保存数据,因此随着时间的流逝,AOF文件会越来越多,将会增加服务器的存储压力,同时也会造成Redis重启速度变慢。由此诞生了AOF重写功能。
  • AOF文件重写:直接读取Redis服务器当前的状态,并保存为AOF文件。不管记录了多少命令,执行重写以后,只会保存当前状态信息。
  • AOF重写实现:满足两个基本条件才能重启
    1. auto-aof-rewrite-min-size:允许AOF重写的最小文件容量,默认为64mb.
    2. auto-aof-rewrite-percentage:AOF文件重写的大小比例,默认值为100,表示100%,也就是只有当前AOF文件,比最后一次的AOF文件大一倍时,才会启动AOF文件重写。

在这里插入图片描述
在客户端执行bgrewriteaof命令就可以手动触发AOF重写持久化

  • AOF重写的流程:生成一个全新的文件,并把当前数据的最小操作命令保存到新文件上,当把所有的数据都保存到新文件之后,Redis会交换两个文件,并把最新的持久化操作命令追加到新文件上。
手动触发

执行bgrewriteaof命令就可以手动触发AOF重写持久化

在这里插入图片描述

2.2.3AOF配置文件说明

# 是否开启 AOF,yes 为开启,默认是关闭
appendonly no

# AOF 默认文件名
appendfilename "appendonly.aof"

# AOF 持久化策略配置
# appendfsync always
appendfsync everysec
# appendfsync no

# AOF 文件重写的大小比例,默认值是 100,表示 100%,也就是只有当前 AOF 文件,比最后一次的 AOF 文件大一倍时,才会启动 AOF 文件重写。
auto-aof-rewrite-percentage 100

# 允许 AOF 重写的最小文件容量
auto-aof-rewrite-min-size 64mb

# 是否开启启动时加载 AOF 文件效验,默认值是 yes,表示尽可能的加载 AOF 文件,忽略错误部分信息,并启动 Redis 服务。
# 如果值为 no,则表示,停止启动 Redis,用户必须手动修复 AOF 文件才能正常启动 Redis 服务。
aof-load-truncated yes

2.2.4AOF优缺点

  • 优点: 保存文件更完整

    1. 持久化保存得到数据更加完整,提供了三种策略持久化的方式,按照每次操作保存,每秒保存一次,以及跟随系统的持久化保存。其中每秒保存一次,从数据的安全性和性能两方面考虑是个优解,也是AOF默认的策略。
    2. 由于AOF是命令追加写入的方式,所以不会出现文件损坏的问题,即使出现意外情况,也可以通过redis-check-aof工具轻松的修复;
    3. AOF持久化文件,非常容易解析。即使使用了flushall命令清空了数据库,只要使用AOF文件,删除最后的flushall命令,重启Redis就可以恢复之前误删的数据。
  • AOF缺点: 文件过多过大,恢复速度较慢

    1. 相同的数据集而言,AOF文件大于RDB文件,RDB采用的是二进制存储。
    2. 在redis负载比较高的情况下,RDB比AOF性能更好。
    3. RDB使用快照的方式来持久化保存数据,而AOF只是保存每次执行的命令。从理论上而言RDB比AOF更健壮。
  • 如果AOF和RDB同时开启,则只加载appendonly.aof

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值