- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我是这个话题的新手。看了一些文章,问了几个人,还是不明白你们在一个问题上是怎么做的。
有 UI 客户端向多个后端实例发出请求(目前 session 是否具有粘性无关紧要),并且这些实例连接到一些高度可用的数据库集群(可能是 Cassandra 或 Elasticsearch 的其他东西)。假设后端实例没有专门绑定(bind)到一个或集群的机器,而是它对数据库的每个请求都可能由不同的机器提供服务。一个客户端创建一些记录,它被同步或异步存储到集群的一台机器上,然后最终被复制到其余的数据库机器上。然后另一个客户端请求列表或记录,该请求最终由尚未收到复制更改的远程机器提供服务,因此客户端看不到记录。嗯,这很糟糕,但还不算丑陋。
但是请考虑第二个客户端访问有记录的机器,将其显示在列表中,然后刷新列表,这一次访问远程机器并且再次看不到记录。这是非常奇怪的行为,不是吗?它甚至可能变得更糟:客户端成功请求记录,开始对其进行一些编辑,然后尝试将更新存储到数据库,这一次命中远程机器说“我对您要更新的记录一无所知”。这是用户在做完全合法的事情时会看到的错误。
那么防止这种情况的常见做法是什么?到目前为止,我只看到三种解决方案。
1) 实际上不是一个解决方案而是一个政策:忽略这个问题,而是尽可能地加速集群以保证 99.999% 的更改将在整个集群上复制,例如 0.5 秒(很难想象一些用户会尝试在这段时间内对一条记录发出多个连续请求;他当然可以发出多个读取请求,但在那种情况下他可能不会注意到结果之间的不一致)。即使有时出现问题并且用户面临问题,好吧,我们也接受它。如果失败者不高兴并向我们投诉(可能每周一次或每小时一次),我们只会道歉并继续。
2) 在用户 session 和特定数据库机器之间引入亲缘关系。这有帮助,但需要 DB 的明确支持,并且还会损害负载平衡,并在 DB 机器出现故障并且 session 需要重新绑定(bind)到另一台机器时引发并发症(但是在 DB 的适当支持下我认为这是可能的; 说 Elasticsearch 可以接受路由 key ,我相信如果目标分片出现故障,它只会将亲和性链接切换到另一个分片 - 尽管我不完全确定;但即使发生重新绑定(bind),另一台机器也可能包含旧数据:)).
3) 依靠单调一致性,即某种方法可以确保来自客户端的下一个请求将获得不早于前一个请求的结果。但是,据我所知,这种方法还需要 DB 的明确支持,比如能够将一些“全局版本时间戳”传递给集群的平衡器,它将与所有机器时间戳上的最新数据进行比较,以确定哪些机器可以服务请求。
还有其他好的选择吗?还是这三个被认为足够好用?
附言我现在的具体问题是 Elasticsearch; AFAIK 那里不支持单调读取,但看起来选项 #2 可能可用。
最佳答案
Apache Ignite 具有用于 key 的主分区和备份分区。除非您设置了 readFromBackup
选项,否则您将始终从其内容被认为是可靠的主分区读取数据。
如果一个节点消失,事务(或操作)应该由剩余节点传播或回滚。
请注意,Apache Ignite 不执行最终一致性,而是执行强一致性。这意味着您可以观察到节点丢失期间的延迟,但不会观察到不一致的数据。
关于elasticsearch - 最终一致性——如何避免幻影,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51277542/
GhostScript PDF/A 生成好像有错误 当您通过 GhostScript 生成 PDF/A 文档时,当您单击 Adobe Reader 时,会出现一个一致性选项卡,其中显示: “一致性
我有一个需要测试的 XPath 引擎实现。 是否有一组标准的一致性测试可以用来验证是否符合 XPath 规范(与 XSLT 相关)。 什么将是完美的 XML 文档 XPath 表达式和预期的结果。 最
帮助我了解在这种情况下我可以期望与 MongoDB 的一致性级别。 我们正在运行一个副本集,其中 Mongoid 中的 consistency 标志设置为 strong,这意味着只读到 master。
假设我有一个采用一个参数的方法。 此参数应满足以下要求: 'of type':方法需要知道参数属于特定类(或子类)。 'implements interface':方法需要知道参数实现了特定的接口(i
当协议(protocol)将属性声明为可选而具体类型将其声明为非可选时,如何使具体类型符合协议(protocol)? 这是问题所在: protocol Track { var trackNum
我正在考虑使用浏览器的 navigator.mimeTypes 数组作为第三级用户/浏览器标识符。例如,当我在 Chrome 上运行时... console.log(navigator.mimeTyp
我有以下协议(protocol): protocol ProtoAInput { func funcA() } protocol ProtoA { var input: ProtoAI
如果选择“最终”一致性,则发生写入的区域内的一致性是什么? 如果我只需要区域强一致性,应该选择哪个选项? 最佳答案 如果您需要在主要区域内进行强读取,则应该选择强一致性或有界过时一致性。 关于azur
您好,我是一名初学者,目前正在尝试学习 java 编程。课本上的问题: 编写一个程序来帮助人们决定是否购买混合动力汽车。你的程序的输入应该是:•新车的成本•预计每年行驶里程•预计汽油价格 •每加仑英里
我正在尝试制作一个可以在 UILabel 上使用的 Swift 协议(protocol), UITextField , 和 UITextView包含他们的text , attributedText ,
我有一个类扩展: extension UICollectionViewCell { class func registerFromNibInCollectionView(collectionV
为了在 Swift 中模拟对象进行测试,我通常遵循这样的模式:编写一个协议(protocol)来描述我想要的对象的行为,然后使用 Cuckoo 为其生成模拟以进行测试。 通常,这些协议(protoco
假设我有两个非通用协议(protocol)(1) protocol StringValue { var asString: String {get} } protocol StringProv
我有一组协议(protocol)可以在 UITableView 中显示一个元素: protocol TableRepresentableRow { var title: String { get
关闭。这个问题是not reproducible or was caused by typos .它目前不接受答案。 这个问题是由于错别字或无法再重现的问题引起的。虽然类似的问题可能是on-topi
用“class”标记 CacheManager 解决了我的问题。 案例:一个简单的缓存器,mutating get 不是我想要的,那么对于引用类型或类类型应该怎么做? protocol Cacher
我想要一个符合协议(protocol)的变量,但是 swift 编译器告诉我协议(protocol)没有确认。 protocol A {} protocol B { var a : A { g
如果我有一个类 Christmas 和一个协议(protocol) Merry,要使 Christmas 符合 Merry,很多人会这样做: class Christmas { ... } e
@objc public protocol P1 { func p1foo() } @objc public protocol P2 { func p2foo() } class A: NSO
我有一些结构符合的基本协议(protocol)(模型)。它们也符合 Hashable protocol Model {} struct Contact: Model, Hashable { v
我是一名优秀的程序员,十分优秀!