当前位置: 首页 > news >正文

大同建设网站赤蚁网站建设

大同建设网站,赤蚁网站建设,凡科建站下载,英语门户网站织梦源码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主进程的性能也会有一定的影响。
http://www.pierceye.com/news/162629/

相关文章:

  • 成都网站建设哪家技术好关于做网站的搞笑段子
  • 网站的设计制作流程计算机网站开发要考什么证
  • 个人域名 公司网站百度推广和网站建设
  • 哪里有做网站服务抖音开放平台是什么
  • 公司网站上传不了图片建设网站条件
  • 精美公司网站源码婚礼策划网站设计
  • 线上设计师网站网络维护是什么意思
  • 培训网站建设阿里云如何建设网站
  • 手机网站列表模板做一钓鱼网站吗
  • 太原网站建设方案策划请问有重庆有做网站吗
  • 网站备案购买语音网站怎么做
  • ftp上传文件到网站深圳成品网站超市
  • 网站开发时app打开很慢建设网站还要云服务器吗
  • 网站设计方案应该怎么做网站自适应开发
  • 徐州手机网站设计青龙县建设局网站
  • 罗湖网站建设费用帮忙做文档的网站
  • 如何在720云网站做全景视频域名注册网站查询工具
  • 网站定制开发流程和功能wordpress怎么看访问
  • 浙江省互联网建设网站python开发手机网站开发
  • 做网站需要多少钱一年动漫制作技术是学什么
  • 刘洋网站建设 够完美保卫处网站建设
  • 个人怎么申请营业执照北京朝阳区优化
  • 免费的舆情网站不用下载直接打开江西城乡建设网站
  • 那些网站是做金融行业网站主目录权限配置
  • 本地网站做不大wordpress 安全设置
  • 宁波教育平台网站建设广告行业怎么找客户
  • php企业网站开发实验总结商城网站建设模板
  • 单词优化和整站优化建设银行的网站特点
  • 厦门淘宝网站设计公司wordpress大前端dux5.2
  • 淮南网站seo网络信息发布平台