返回顶部
首页 > 资讯 > 数据库 >Riak请求过程是什么以及Riak有几种失败场景
  • 145
分享到

Riak请求过程是什么以及Riak有几种失败场景

2024-04-02 19:04:59 145人浏览 安东尼
摘要

Riak请求过程是什么以及Riak有几种失败场景,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。  CAP原理告诉我们,一致性,

Riak请求过程是什么以及Riak有几种失败场景,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。

  CAP原理告诉我们,一致性,可用性和分区容忍性三者最多只能偏重其中两个。在NoSQL系统中,分区容忍性(P)几乎已经成为必选项。于是很多Nosql选择了牺牲一定一致性的做法。下面编程网小编来讲解下Riak请求过程是什么?Riak有几种失败场景?

  Riak请求过程是什么

  首先介绍一下Riak的请求处理过程,以数据冗余N份存储,每次读取其中的R份,写操作需要写W份。

  通过计算得出请求的key所在的N个节点

  向这N个节点依次发起请求

  等待这N个节点中的W个(如果是写操作的)或R个(如果是读操作)返回成功

  返回相应的数据给客户端。

  Riak有几种失败场景

  1.读取数据前其中一个节点故障

  数据以W=3成功写入三份

  其中一个节点故障

  数据再以R=3读取三份,发起三个请求

  此次读操作会返回了not_found

  而这次系统在检测到了数据只有两份,会启动修复器将数据备份一份到secondary节点上,以保证有三份备份

  后续的读操作将会从primary上读到两份,从secondary上读到一份数据,以实现成功读到三份数据。

  2.读取数据前其中两个节点故障

  数据以W=3成功写入三份

  其中两个节点故障

  数据再以R=3读取三份,发起三个请求

  此次读操作会返回了not_found

  后续的读操作将会从primary上读到一份,从secondary上读到两份数据,以实现成功读到三份数据。

  3.读取数据前三个节点全部故障

  数据以W=3成功写入三份

  其中三个节点故障

  数据读取操作将会永远返回not_found,直到某个节点恢复

  4.写操作前一个节点故障

  一个节点故障

  数据以W=3发起三个写请求

  一个secondary节点承担了其中的一个写请求

  后面的读请求会正常的读到三份数据

  5.写操作前一个节点故障,后来又恢复了

  一个节点故障

  数据以W=3发起三个写请求

  一个secondary节点承担了其中的一个写请求

  故障节点又恢复了

  在60秒内,一个叫hintedhandoff的过程会启动,将secondary中的数据迁移到刚刚恢复的primary中

  在hintedhandoff过程完成后,数据就恢复正常了

  6.在hintedhandoff过程中进行读写操作

  在hintedhandoff过程中,由于原来的primary节点是启动的,所以数据读写操作都会到这个节点上来执行,这时候可能由于一些值还没有备份回来,所以会导致这个节点暂时的not_found返回。

  7.在两个primary节点故障后一个又恢复期间进行读写操作

  这时候刚刚恢复的节点会进行hintedhandoff过程,而读写操作依然会由于not_found的发生而启动修复器进行数据备份到secordary中。

看完上述内容是否对您有帮助呢?如果还想对相关知识有进一步的了解或阅读更多相关文章,请关注编程网数据库频道,感谢您对编程网的支持。

您可能感兴趣的文档:

--结束END--

本文标题: Riak请求过程是什么以及Riak有几种失败场景

本文链接: https://lsjlt.com/news/61757.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • Riak请求过程是什么以及Riak有几种失败场景
    Riak请求过程是什么以及Riak有几种失败场景,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。  CAP原理告诉我们,一致性,...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作