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

做视频网站需要什么服务器配置电脑速成班短期电脑培训班

做视频网站需要什么服务器配置,电脑速成班短期电脑培训班,263企业邮箱免费登录入口,免费开源wordpress主题RDB快照 与AOF记录写操作命令不同#xff0c;RDB直接记录内存中的二进制数据#xff0c;reids恢复数据时#xff0c;直接将RDB文件加载到内存中就可以了#xff0c;听起来是不是RDB完虐AOF#xff1f;那么看完本文#xff0c;会让你的态度转变#xff0c;因为RDB的缺点…RDB快照 与AOF记录写操作命令不同RDB直接记录内存中的二进制数据reids恢复数据时直接将RDB文件加载到内存中就可以了听起来是不是RDB完虐AOF那么看完本文会让你的态度转变因为RDB的缺点比AOF更糟糕 RDB快照怎么用 Redis 提供了两个命令来生成 RDB 文件分别是 save 和 bgsave他们的区别就在于是否在「主线程」里执行 执行了 save 命令就会在主线程生成 RDB 文件由于和执行操作命令在同一个线程所以如果写入 RDB 文件的时间太长会阻塞主线程执行了 bgsave 命令会创建一个子进程来生成 RDB 文件这样可以避免主线程的阻塞 RDB 文件的加载工作是在服务器启动时自动执行的Redis 并没有提供专门用于加载 RDB 文件的命令。 Redis 还可以通过配置文件的选项来实现每隔一段时间自动执行一次 bgsave 命令默认会提供以下配置 save 900 1 save 300 10 save 60 10000别看选项名叫 save实际上执行的是 bgsave 命令也就是会创建子进程来生成 RDB 快照文件。 只要满足上面条件的任意一个就会执行 bgsave它们的意思分别是 900 秒之内对数据库进行了至少 1 次修改300 秒之内对数据库进行了至少 10 次修改60 秒之内对数据库进行了至少 10000 次修改。 看上去RDB 和 AOF 有几点相似之处 1.都有在主进程、子进程进行持久化的方式 2.主进程中的持久化操作和主进程的其它操作是串行的有阻塞主进程的风险 3.fork出子进程进程持久化势必会出现持久化过程中主进程添加新数据而造成父子进程数据不一致的问题 注意 前文没有详细说明RDB快照是全量快照也就是说每次执行save或bgsave命令会将当前数据库的全部内存数据进行记录 现在聪明的你发现RDB的致命缺陷了吗 RDB的致命缺陷 1.由于RDB是对数据库当前内存数据的全量快照势必造成前后两次生成的RDB文件有重复部分并且重复的数量会越来越大 2.全量快照导致了RDB文件会随数据库的体积增大而增大在生成较大RDB文件时会对redis造成性能影响这也是RDB需要使用bgsave在子进程中持久化的原因 3.正是由于生成较大体积的RDB文件的开销较大因此RDB操作不能像AOF那样频繁因此RDB有持久化的窗口期会造成数据丢失的风险而相比之下AOF安全的多 说说bgsave的问题 bgsave创建一个子进程进行RDB持久化操作与AOF类似子进程只拥有fork时刻的父进程数据库状态在子进程持久化过程中新加入到父进程的数据在子进程中是没有的这部分数据只能在下一次RDB时进行持久化如果在下一次RDB前redis宕机那么这部分数据就会丢失这部分丢失的数据是比AOF要多的因为RDB对新数据的持久化频率远低于AOF 终极方案——RDBAOF混合持久化 我在“AOF持久化”的文章中介绍到AOF有解决持久化过程中由于新数据的加入造成父子进程数据不一致而导致的数据丢失方案————持久化过程中将新数据追加到父进程、子进程从而实现数据同步 但RDB不同由于RDB是对数据库的全量快照没有用到AOF所使用的缓冲区那么持久化过程中的新数据丢失问题就没办法解决了吗 解决方案是AOF 如果想要开启混合持久化功能可以在 Redis 配置文件将下面这个配置项设置成 yes aof-use-rdb-preamble yes混合持久化工作在 AOF 日志重写过程。 开启了混合持久化后在AOF使用fork创建子进程来进行AOF重写时不再将数据库中的内存数据转换成命令而是像RDB一样直接将内存数据以RDB格式写入到FOD文件中在这个过程中父进程新加入的数据也会追加到AOF子进程的aof重写缓冲区内这部分数据是AOF格式写入完成后通知主进程将新的含有 RDB 格式和 AOF 格式的 AOF 文件替换旧的的 AOF 文件。 也就是说使用了混合持久化AOF 文件的前半部分是 RDB 格式的全量数据后半部分是 AOF 格式的增量数据。 混合持久化对AOF和RDB的优化 1.混合持久化优化了AOF重写时将数据库的内存数据转换成命令的这个过程实际上将内存数据转换成命令这步操作是冗余的AOF重写之所以进行这个转换是为了保证AOF文件格式的一致性 而混合持久化的AOF文件中有RDB和AOF两种文件格式避免了将内存数据转换成命令的步骤提高了持久化效率 2.RDB在bgsave持久化过程中父进程添加的新数据有丢失的风险且没有手段规避AOF遇到同样的问题有解决方案而混合持久化将RDB有丢失风险的这部分数据采用了AOF的方案追加命令到子进程的aof重写缓冲区并以aof格式保存 总结 混合持久化的方案结合了RDB的快速加载、AOF的数据安全数据丢失少的优点一定程度规避了RDB的易丢失数据、AOF加载慢的缺点 重启 Redis 加载数据的时候由于前半部分是 RDB 内容这样加载的时候速度会很快。 加载完 RDB 的内容后才会加载后半部分的 AOF 内容这里的内容是 Redis 后台子进程重写 AOF 期间主线程处理的操作命令可以使得数据更少的丢失 推荐学习 https://xxetb.xetslk.com/s/p5Ibb
http://www.hkea.cn/news/14336680/

相关文章:

  • 网站开发专业介绍wordpress视频手机版
  • 网站建设学费多少钱商品小程序怎么制作
  • wordpress网站分析网站怎么快速排名
  • 医药类网站怎么做seo天津专业做网站公司
  • 南充住房和城乡建设厅网站网站标题可以修改吗
  • 站长如何做视频类网站网站安全检测中心
  • 发布网站需要备案吗湖南长沙景点
  • 淘宝网站制作培训wordpress地址怎么打开
  • 塑胶制品 东莞网站建设用手机可以做网站吗
  • 网站建设响应式开发一个游戏需要多少钱
  • 潍坊路通工程建设有限公司网站c语言软件开和网站开发区别
  • 政务信息公开和网站建设自评建设工程项目
  • 深圳企业推广网站手机网站开发要多久
  • discuz做淘客网站上海市建设干部学校网站
  • 个人网站涉及企业内容做网站要哪些人员
  • 成都推广系统织梦网站是不是容易做seo
  • 北京网站建设公司华网天下官网海外网站空间
  • 海外网站建设公司用dw做购票网站
  • 珠海网站建设专业设计怎样建设网站后台
  • 网站seo推广优化一家做公司点评的网站
  • 台州外贸网站网站建设与架构男友实验
  • 织梦网站源码好吗陕西建设集团韩城公司网站
  • 北京网站空间建设网站的网页设计
  • 广东手机网站开发多少常州谷歌推广
  • 领导交给你一个网站你该怎么做网络营销软件价格
  • 做机械设备销售的那个网站好家具设计理念
  • 连锁加盟网站制作快速微信网站建设
  • 城乡建设部网站ps做的网站首页
  • 自己的做网站自建网站平台有哪些功能
  • 免费源码资源站做一个微信小程序游戏需要多少钱