首页 > 数据库 >Redis-基础(逐步完善)

Redis-基础(逐步完善)

时间:2023-04-07 12:35:07浏览次数:43  
标签:AOF fsync 文件 基础 Redis RDB 逐步完善 操作

Redis

持久化RDB/AOF 命令 RDB(dump.rdb文件) 适用于大规模数据恢复,且对数据完整性和一致性不高的情况 把当前进程数据生成快照保存到硬盘的过程 RDB文件的处理 保存位置:dbfilename 压缩:rdbcompression,默认开启LZF压缩,会消耗CPU 校验:rdbchecksum,使用CRC64算法校验 RDB持久化触发方式 :手动触发 save:阻塞当前Redis服务器,直到RDB过程完成为止,对于内存比较大的实例容易造成长时间的阻塞,线上不建议使用 bgsave:阻塞只发生在fork阶段,一般时间很短。Redis进程执行fork操作创建子进程,RDB持久化由子进程负责,完成后自动结束。   自动触发的情况 配置文件使用save相关配置,默认15分钟至少一次修改,5分钟至少10次修改,1分钟至少10000次修改时 从节点执行全量复制,主节点自动执行bgsave生成RDB文件发送给从节点 执行debug reload命令重新加载Redis 默认情况下执行shutdown命令时,如果没有开启AOF持久化,则自动执行bgsave 优缺点 优点 RDB是一个紧凑压缩的二进制文件,代表Redis某一个时间点的快照,非常适用于备份,全量复制等场景 Redis加载RDB恢复速度远快于AOF的方式 缺点 最后一次持久化后的数据可能丢失 RDB没法做到实时持久化,因为bgsave每次运行时间都要执行fork操作创建子进程,频繁执行成本过高 老版本RDB文件可能无法兼容新版本RDB文件 AOF(append-only-file):appendonly yes开启 以独立日志的方式记录每次的写命令(包括flushall),解决数据持久化的实时性 执行了flush操作,就只能从AOF恢复,RDB会清空   流程 命令写入write:所有写操作会追加到aof_buf缓冲中 aof文件使用RESP协议  使用aof_buf缓冲能减小硬盘负载,并且方便Redis提供多种向硬盘同步的策略 文件同步fsync:AOF根据相应的策略向磁盘做同步操作 AOF缓冲区同步策略(由配置参数appendfsync) always(不建议配置):每次同步都要调用fsync同步AOF文件,数据安全性最高,但导致Redis的写入性能下降 everysec(默认):fsync操作由专门的线程每秒调用一次,同时兼顾性能与数据安全,在系统突然宕机的情况下也不会丢失超过两秒的数据 no:不对AOF做fsync同步,同步由操作系统负责,但操作系统的同步周期不可控,性能最高,但不能保证数据安全性 使用write和fsync的说明 write会触发延迟写机制,linux系统提供页缓冲区来提高硬盘性能,write在写入系统缓冲区后直接返回,同步硬盘操作依赖于操作系统调度机制 fsync针对单个文件操作,做强制硬盘同步,fsync将阻塞直到写入硬盘操作完成后返回,保证数据持久化 文件重写rewrite:(bgrewriteaof命令)随着AOF文件增大,需要定期对AOF文件做重写操作 压缩AOF文件大小,降低文件占用空间 进程已经超时的数据不写入文件 旧AOF含有的的无效命令,新的AOF文件只保留最终数据的写命令 多条写命令合并成一个  重写后的新 AOF 文件包含了恢复当前数据集所需的最小命令集合   触发条件 手动触发:直接调用bgrewriteaof命令 自动触发:同时满足以下两个条件时触发 根据auto-aof-rewrite-min-size(触发AOF重写时的文件最小体积,默认为64M) 根据auto-aof-rewrite-percentage 重启加载:Redis重启时,优先从AOF加载命令恢复数据,AOF文件不存在才从RDB加载 性能优化建议 RDB只做后被用途,建议只在Slave上持久化RDB文件,而且只设置15分钟备份一次就行了 开启AOF在最坏情况下也只会丢失不超过两秒的数据,坏处是带来了持续的IO,并且rewrite过程中产生的新数据写到新文件的阻塞几乎是不可避免的,只要硬盘许可,应该尽量减少AOF rewrite的频率,AOF重写的基础大小默认值64MB太小,可以改到5G以上,默认超过原大小100%时可以改到适当数值 如果不开启AOF,仅靠主从复制实现高可用也可以,这样能剩下大笔IO开销,也减少了rewrite带来的系统波动,代价是master/slave同时宕掉,会丢失十几分钟的数据   问题定位和优化 fork操作 控制Redis实例的最大内存,fork操作跟内存量成正比,建议每个实例控制在10GB以内 避免物理内存不足导致fork失败 降低fork操作频率,如放宽AOF触发时机 子进程开销监控和优化 子进程负责把进程内数据分批写入文件,该过程是CPU密集型操作,通常子进程对单核CPU利用率接近90% 避免和其他CPU密集型操作服务部署在一起 部署多个Redis实例时,尽量保证同一时刻只有一个子进程执行重写操作 避免大量写入时做子进程重写操作,这样将导致父进程维护大量页副本,造成内存消耗 AOF追加阻塞 当系统资源繁忙时fsync操作会造成Redis主线程阻塞 主线程会对比上一次AOF同步时间,如果距上次同步时间在2秒内就直接返回,否则主线程阻塞 对AOF追加阻塞的优化 不和其他高硬盘负载的服务部署在一起,如存储服务,消息队列服务等 AOF重写会消耗大量磁盘IO,可以开启配置no-appendfsync-on-rewrite,表示在AOF重写期间不做fsync,默认关闭 RDB-AOF混合持久化 先以RDB格式写入全量数据,再追加增量日志 这样既可以提高aofrewrite的恢复速度,也可以减少文件大小,还能保证数据完整性 Redis缓存设计 Redis内存理解和优化 复制 哨兵 集群

标签:AOF,fsync,文件,基础,Redis,RDB,逐步完善,操作
From: https://www.cnblogs.com/cheng020406/p/17295769.html

相关文章

  • LLaMA:开放和高效的基础语言模型
    LLaMA:开放和高效的基础语言模型论文:https://arxiv.org/pdf/2302.13971.pdf代码:https://github.com/facebookresearch/llama前言我们介绍了LLaMA,这是一个参数范围从7B到65B的基础语言模型集合。我们在数以万亿计的标记上训练我们的模型,并表明有可能完全使用公开可用的数据集来......
  • K8S基础环境部署0
    基础环境部署1)前期准备(所有节点)1、修改主机名和配置hosts先部署1master和2node节点,后面再加一个master节点#在172.17.35.60执行hostnamectlset-hostnamek8s-m60#在172.17.35.62执行hostnamectlset-hostnamek8s-n62#在172.17.35.63执行hostnamectlset-ho......
  • 结构体基础知识
    定义struct变量后,在main函数的调用时//定义时struct不可以省略structsudents1;//这个可以省略s1.name="name";structsudents2={"学生","18"};cout<<s2.name结构体数组在main函数中structStudentstuarray[3]={{"张三",21,34},//stuarray[1]{&qu......
  • geant4基础操作
    geant4官网:Geant4(cern.ch)打开B1实例的方法:进入用户文件夹/geant4_workspace/B1/build右键点击在终端中打开输入cmake..进行编译以及生成配置文件(预编译)再输入make合并编译器生成的目标exampleB1可执行文件输入./exampleB1对可执行文件运行,生成可视化界面配置参数文......
  • 【web 开发基础】PHP 的流程控制之多向条件分支结构 -PHP 快速入门 (14)
    多向条件分支结构(elseif)条件分支结构其实是我们生活中常用的一种一种逻辑结构,类似于我们常用的(如果...那么...否则...就.....).本文中的elseif子句,和此名称暗示的一样,就是if和else的组合,相当于(...else{if(表达式){{语句块;}}})。和else一样,它延伸了if语句,条件分支结构中els......
  • 应急响应基础技能
    windows任务计划列表1.计算机管理窗口,选择系统工具中任务计划程序中的任务计划程序库选项可以查看任务计划的名称,状态,触发器等详细信息2.powershell中输入get-scheduledtask可以查看当前系统所有任务计划信息任务路径,名称,状态等详细信息3.命令行中输入schtasks......
  • Java基础知识点(抽象类)
    封装:对象代表什么,就得封装对应的数据,并提供数据对应的行为。一:抽象方法和抽象类的定义将共性的行为(方法)抽取到父类之后,由于每一个子类执行的内容是不一样,所以,在父类中不能确定的具体的方法体,该方法就可以定义为抽象方法。抽象类:如果一个类中存在抽象方法,那么该类就必须声明抽象类。......
  • Java基础知识点(抽象类)
    封装:对象代表什么,就得封装对应的数据,并提供数据对应的行为。一:抽象方法和抽象类的定义将共性的行为(方法)抽取到父类之后,由于每一个子类执行的内容是不一样,所以,在父类中不能确定的具体的方法体,该方法就可以定义为抽象方法。抽象类:如果一个类中存在抽象方法,那么该类就必须声明抽象类。......
  • MYSQL基础知识之多表查询
    1、多表关系在数据表中,各个表结构之间存在着各种关系(一对一、一对多、多对多)。一对一关系:示例:学生与学生详情的关系,一个学生对应一个详细情况,一个详细情况对应一个学生。实现:在任意一方加入外键,关联另外一方的主键,并且设置外键为唯一的UNIQUE。一对多关系:示例:学生与班级的关......
  • Redis 持久化机制
    目录Redis数据持久化RDB(RedisDatabase)触发快照的时机AOF(AppendOnlyFile)AOF日志写入过程AOF重写机制AOF重写写时复制AOF重写缓冲区子进程重写的优点总结RDB+AOF组合Redis数据持久化Redis提供了四种持久化策略:RDB(RedisDatabase)、AOF、RDB+AOF和不持久化。RDB......