中国寰球工程有限公司网站设计,wordpress接入打赏,网站开发 居易国际,合肥网站建站报广告代理redis高可用相关知识 在web服务器中#xff0c;高可用是指服务器可以正常访问的时间#xff0c;衡量的标准是在多长时间内可以提供正常服务(99.9%、99.99%、99.999%等等)。
但是在Redis语境中#xff0c;高可用的含义似乎要宽泛一些#xff0c;除了保证提供正常服务( 如主… redis高可用相关知识 在web服务器中高可用是指服务器可以正常访问的时间衡量的标准是在多长时间内可以提供正常服务(99.9%、99.99%、99.999%等等)。
但是在Redis语境中高可用的含义似乎要宽泛一些除了保证提供正常服务( 如主从分离、快速容灾技术)还需要考虑数据容量的扩展、数据安全不会丢失等。 redis持久化 1.持久化是什么
持久化是最简单的高可用方法主要作用是数据备份也就是把redis缓存中内存中的数据把他保存到本地的硬盘中。
特点冷备份必须要停服务才能数据备份 2.持久化的两种方式
RDB持久化原理是将Reids在内存中的数据库记录定时保存到磁盘上。定时对内存中的数据生成快照以文件形式保存在硬盘中AOF持久化append only file原理是将Reids 的操作日志以追加的方式写入文件类似于MySQL的binlog。类似于Mysql的二进制日志以追加的方式将写和删的操作命令记录到AOF文件中 rdb的持久化 rdb持久化指在指定时间间隔内将内存中当前进程中的数据生成快照保存到硬盘快照持久化用二进制压缩存储。保存的文件名后缀.rdb。redis启动时可以直接读取快照文件实现数据恢复。 rdb的触发机制
1手动触发
save命令和bgsave命令都可以生成RDB文件。
save命令会阻塞Redis服务器进程直到RDB文件创建完毕为止在Redis服务器阻塞期间服务器不能处理任何命令请求。而bgsave命令会创建一个子进程由子进程来负责创建RDB文件父进程即Redis主进程则继续处理请求。bgsave命令执行过程中只有fork子进程时会阻塞服务器而对于save命令整个过程都会阻塞服务器因此save已基本被废弃线上环境要杜绝save的使用。
save是使用主进程创建。杜绝使用
示意图 2自动触发
在自动触发RDB持久化时Redis 也会选择bgsave而不是save来进行持久化。
自动触发最常见的情况是在配置文件中通过 save m n 指定当m秒内发生n次变化时会触发bgsave。
bgsave bgsave就是主从复制的机制
创建一个子进程让子进程创建rdb文件 bgsave特点 主进程会通过fork机制创建一个子进程子进程的创建过程中主进程会阻塞子进程创建完毕主进程会停止阻塞。子进程来创建rdb文件。创建完成之后通知主进程更新通知信息 vim /etc/redis/6379.conf #编辑配置文件----219行--以下三个save条件满足任意一一个时都会引起bgsave的调用save 900 1 #当时间到900秒时如果redis数据发生了至少1次变化则执行bgsavesave 300 10 #当时间到300秒时如果redis数据发生了至少10次变化则执行bgsavesave 60 10000 #当时间到60秒时如果redis数据发生了至少10000次变化 则执行bgsave----242行--是否开启RDB文件压缩rdbcompression yes----254行--指定RDB文件名dbfilename dump.rdb----264行--指定RDB文件和AOF文件所在目录dir /var/lib/redis/6379 若将修改为 save 60 2会有怎么样的结果 Save 60 2 的含义是60秒内有两次更新才会记录bgsave 接下来60秒内创建2个以上的文件 如果只有一个创建然后exit就会等待900秒 配置文件内有所更新而且连带第一次的一起更新 AOF持久化 RDB持久化是将进程数据写入文件而AOF持久化则是将Redis执行的每次写、删除命令记录到单独的日志文件中查询操作不会记录。当Redis重启时再次执行AOF文件中的命令来恢复数据。重放命令进行恢复与RDB相比AOF的实时性更好因此已成为主流的持久化方案。 AOF的开启配置
vim /etc/redis/6379.conf----700行---修改开启AOFappendonly yes----704行---指定AOF文件名称appendfilename appendonly.aof----796行---是否忽略最后一条可能存在问题的指令aof-load-truncated yes #Redis恢复时发现AOF文件的末尾被截断了会忽略最后一条可能存在问题的指令。默认值yes。即在aof写入时可能发生redis机器运行崩溃AOF文件的末尾被截断了这种情况下yes会继续执行并恢复尽量多的数据而no会直接恢复失败报错退出。/etc/init.d/redis_6379 restart #重启redisls /var/lib/redis/6379/ #查看是否生成了aof文件 AOF缓存区的同步文件策略存在三种同步方式它们分别是
appendfsync always命令写入aof_buf后立即调用系统fsync操作同步到AOF文件。安全性高性能低。appendfsync no当缓冲区被填满或超过了指定时限后默认30秒才将缓冲区的数据写入到硬盘里。性能高但安全性低。appendfsync everysec每秒同步一次是性能和数据安全性的平衡因此是Redis的默认配置。
appendfsync always写入过程中立即调用系统的操作写入到文件这次写入都执行同步硬盘的性能有瓶颈。硬盘的寿命也会大大降低appendfsync everysec
命令写入调用write操作write操作结束后线程会返回同步文件由专门的线程每秒调用一次。这是一个折中的策略是性能和安全性的平衡是的默认配置也是推荐配置appendfsync no写入操作会调用系统的操作但是不对文件进行同步操作系统来同步同步周期是30秒文件同步时间不可控缓冲区会堆积大量数据数据的安全无法保证
aof的备份恢复
vim /etc/redis/6379.conf
cd /var/lib/redis/6379
#检查文件是否生成实现数据恢复
进入redis
set test1 1
set test2 2
set test3 3
vim /var/lib/redis/6379/appendonly.aof
#配置文件会记录所有redis的操作
flushall
/etc/init.d/redis_6379 stop
#停止redis服务
vim /var/lib/redis/6379/appendonly.aof
#根据为位置点删除flushall这个操作
/etc/init.d/redis_6379 restart
#重启服务
进入redis查看文件恢复
实验已经完成 aof的重写功能
随着时间流逝Redis服务器执行的写命令越来越多AOF文件也会越来越大过大的AOF文件不仅会影响服务器的正常运行也会导致数据恢复需要的时间过长。文件重写是指定期重写AOF文件减小AOF文件的体积。需要注意的是AOF 重写是把Redis进程内的数据转化为写命令同步到新的AOF文件不会对旧的AOF文件进行任何读取、写入操作关于文件重写需要注意的另一点是对于AOF持久化来说文件重写虽然是强烈推荐的但并不是必须的即使没有文件重写数据也可以被持久化并在Redis启动的时候导入。因此在一些现实中会关闭自动的文件重写然后通过定时任务在每天的某一时刻定时执行。
注意
重写会消耗性能影响业务不能在业务高峰期进行重写。所以一般会关闭自动重写由定时任务在每天的某一时刻定时执行重写功能。 重写触发条件
手动触发 直接调用bgrewriteaof命令该命令的执行与bgsave有些类似都是fork子进程进行具体的工作且都只有在fork时阻塞。------redis-cli bgrewriteaof自动触发 通过设置auto-aof-rewrite-min-size选项和auto-aof-rewrite-percentage选项来自动执行BGREWRITEAOF。
只有当auto-aof-rewrite-min-size和auto-aof-rewrite-percentage两个选项同时满足时才会自动触发AOF重写即bgrewriteaof操作。
vim /etc/redis/6379.conf----771行----771 auto-aof-rewrite-percentage 100772 auto-aof-rewrite-min-size 64mb-----------------------以下是注释--------------------------------● auto-aof-rewrite-percentage 100 #文件的大小超过基准百分之多少后触发bgrewriteaof。默认这个值设置为100意味着当前aof是基准大小的两倍的时候触发bgrewriteaof。把它设置为0可以禁用自动触发的功能。#即当前AOF文件大小(即aof_current_size)是上次日志重写时AOF文件大小(aof_base_size)两倍时发生BGREWRITEAOF操作。#注意例如上次文件达到100M进行重写那么这次需要达到200M时才进行重写。文件需要越来越大所以一般不使用自动重写。如果使用自动重写需要定期手动重写干预一次让文件要求恢复到100M。● auto-aof-rewrite-min-size 64mb #当文件大于64M时才会进行重写#当前aof文件大于多少字节后才触发。#当前AOF文件执行BGREWRITEAOF命令的最小值避免刚开始启动Reids时由于文件尺寸较小导致频繁的BGREWRITEAOF
文件重写压缩AOF文件的原因
过期的数据不再写入文件。无效的命令不再写入文件如有些数据被重复设值set mykey v1, set mykey v2、 有些数据被删除了set myset vl, del myset等。多条命令可以合并为一个如sadd myset v1, sadd myset v2, sadd myset v3可以合并为sadd myset v1 v2 v3。sadd添加集合
核心
重写之后文件当中命令减少了内容自然减少空间也少了自然而然恢复速度也增加了重写不是必须 RDB和AOF的优缺点 RDB的优缺点
优点
RDB文件紧凑体积小网络传输快适合全量复制恢复速度比AOF快很多。当然与AOF相比 RDB最 重要的优点之一是对性能的影响相对较小。
体积小恢复速度更快对性能影响较小。
缺点
RDB文件的致命缺点在于其数据快照的持久化方式决定了必然做不到实时持久化而在数据越来越重要的今天数据的大量丢失很多时候是无法接受的因此AOF持久化成为主流。此外RDB文 件需要满足特定格式兼容性差如老版本的Redis不兼容新版本的RDB文件。对于RDB持久化一方面是bgsave在进行fork操作时Redis主进程会阻塞另一方面子进程向硬盘写数据也会带来IO压力。
实时性差、兼容性差、在fork子进程时会阻塞父进程。
AOF优缺点
优点
秒级持久化一旦执行立刻写入兼容性好命令写入文本格式保存的命令。
缺点
文件大。恢复速度慢。AOF持久化需要频繁的向磁盘写数据磁盘的I/O压力也很大。对redis主进程的性能也会有一定的影响。