- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
这是 checkAndPut API .
public boolean checkAndPut(byte[] row, byte[] family, byte[] qualifier, byte[] value, Put put)
如果我的理解是正确的,row
参数可以和put
的行不同。但这为什么有用?我认为 checkAndPut
就像硬件架构中的 CompareAndSwap(CAS)
操作。 CAS
正在比较和设置单个变量。但是 checkAndPut
似乎支持对不同行的操作。这有帮助吗?或者我们需要保证 row
实际上与 put
的行相同?
最佳答案
checkAndPut() 是 CAS 的 HBase 变体,现在已弃用,应该改用 checkAndMutate。正如 javadoc 中指定的那样,API 自动检查行/系列/限定符值是否与预期值匹配。如果是,它会添加看跌期权。如果传递的值为空,则检查是否缺少列(即:不存在)。
让我们以列族为“cf1”的表“t1”为例,了解以下场景中的行为-
创建要插入的行
val put = new Put(Bytes.toBytes("r1"))
put.addColumn(Bytes.toBytes("cf1"), Bytes.toBytes("q1"), Bytes.toBytes("v1"))
情况 1 - 表中不存在行、列族或列
Result - 插入一条新记录,res = true
var res = table.checkAndPut(Bytes.toBytes("r1"), Bytes.toBytes("cf1"), Bytes.toBytes("q1"), null, put)
案例 2 - 重新插入在案例 1 中插入的相同记录
结果 - 没有更新插入发生,因为该列已经存在,res = false
res = table.checkAndPut(Bytes.toBytes("r1"), Bytes.toBytes("cf1"), Bytes.toBytes("q1"), null, put)
案例 3 - 使用 cf1:q1 添加新的行键 r2,而 Put 仍设置为 rowkey = r1。
结果 - 没有更新插入发生,我们得到一个异常 - “Action 的 getRow 必须匹配传递的行”,这意味着在 checkAndPut 中设置的行键预计与 Put 中的相同,并且此 API 是按顺序检查行、列族和列限定符是否存在,并对照 Put 中指定的值
res = table.checkAndPut(Bytes.toBytes("r2"), Bytes.toBytes("cf1"), Bytes.toBytes("q1"), null, put)
案例 4 - 向行键 r1 和列 q1 添加新的列族 cf2,而 Put 仍设置为 rowkey = r1,列族 cf1。
结果 - 没有更新插入发生,我们得到一个异常 - “区域 t1,,1524474825488.a1f7efa76e78f38d64f95b63222cbfa8 中不存在列族 cf2。在表 't1' 中......”
res = table.checkAndPut(Bytes.toBytes("r1"), Bytes.toBytes("cf2"), Bytes.toBytes("q1"), null, put)
案例 5 - 我们没有检查 q1,而是在 checkAndPut() 中检查 q2 是否存在
结果 - 这里 API 将检查列 q2 是否存在,在我们的例子中不存在,因此相同的列 q1 将被更新,因为 Put 仍然设置为值 v1,只有时间戳/q1 的版本会改变,res = true
res = table.checkAndPut(Bytes.toBytes("r1"), Bytes.toBytes("cf1"), Bytes.toBytes("q2"), null, put)
案例 6 - 在之前的所有示例中,第 4 个参数都设置为 null,这里我们指定了实际值
结果 - checkAndPut 比较为 q1 指定的值与 Put,因为它比较等于插入发生,res = true
res = table.checkAndPut(Bytes.toBytes("r1"), Bytes.toBytes("cf1"), Bytes.toBytes("q1"), Bytes.toBytes("v1"), put)
案例 3 和案例 4 回答了您问题的最后一部分。
从可用性的角度来看,我认为这个 API 在同一行/列上可能发生大量并发更新的情况下很有用,为了避免任何冲突和过时的数据,我们读取验证然后写入,就像 OCC - https://en.wikipedia.org/wiki/Optimistic_concurrency_control#OCC_phases
要对多行/多列执行更新插入,应该使用 checkAndMutate。 [检查 - What is the difference between Hbase checkAndPut and checkAndMutate? ]
希望这对您有所帮助。
关于hbase - 当要检查的行与 Put 的行不同时,checkAndPut 在什么情况下有用?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49956923/
当我开始学习一门新语言时,我总是觉得我没有以实用、标准的方式进行学习。所以这里有一个关于 jQuery 的问题以及我所做的是否可以接受。 我有 3 张图片。 然后我让 jQuery 检测 $('
基本上,我想知道线程是否有用或必要,或者可能更具体地说,您将使用它的用途和情况。我对线程了解不多,也从未使用过它(我主要使用 C#),并且想知道如果使用它们是否会提高性能或稳定性。如果有人愿意解释一下
这个问题在这里已经有了答案: What is The Rule of Three? (8 个答案) 关闭 7 年前。 嘿嘿。我有一个让我很难过的问题。我自定义了一个普通的拷贝构造函数但它只在我初始化
这个问题在这里已经有了答案: 关闭 12 年前。 Possible Duplicate: Uses for multiple levels of pointer dereferences? 我在 C
我不确定异常在每种语言中的工作方式是否相同,但我使用的是 PHP,我想知道我什么时候做这样的事情: if (!$this->connection[0]->query($this->query)) t
Scala native 是最近发布的,但是他们(现在)使用的垃圾收集器非常rudimentary,因此不适合严肃使用。 所以我想知道:为什么不只将Scala转换为Go (即Scala.js)?这将是
最近,我一直在研究docker及其对SaaS公司的有用性。我花了一些时间学习如何容器化应用程序,并简要了解了什么是docker和容器。我在理解这项技术的实用性时遇到了一些问题。我看过dockercon
我必须根据出现在它们之前的字符串是否是某个关键字“load”从输入文件中读取整数。没有关键数字告诉我们要输入多少个数字。这些数字必须保存到一个数组中。为了避免为扫描的每个附加数字创建和更新新数组,我想
Deferred 对象具有回调池 doneCallbacks、failCallbacks 和 progressCallbacks。 doneCallbacks 和 failCallbacks(以及方法
这个问题在这里已经有了答案: Is there a case where including the same header twice is actually helpful? (6 个答案) 关
我在C++ Programming Language的书上看到了下面的例子 class Ptr { X* operator->( ); }; voide f(Ptr p) { p-
你能不能: template const T &operator[] (unsigned int x) 我的想法是如果你有一个 map如果有一个包装器类可以让您这样做,那就太好了: obj["Int
根据doc这个tutorial , cmp() returns -1 if x y 教程里也说了 cmp() returns the sign of the difference of two nu
我经常读到 It seem that identity monad is useless. It's not... but that's another topic. 那么谁能告诉我它有什么用? 最佳
我已经知道实现和接口(interface)的基础知识。我不明白什么时候使用接口(interface)。有接口(interface)的要求是什么? 例子: /// Interface demo Inte
在一些 R 函数的主体中,例如 lm,我看到对 match.call 函数的调用。正如其帮助页面所述,当在函数内部使用 match.call 时,会返回指定参数名称的调用;这对于将大量参数传递给另一个
在监督学习中,我有典型的训练/测试分割来学习算法,例如回归或分类。关于无监督学习,我的问题是:训练/测试分割是否必要且有用?如果是,为什么? 最佳答案 这取决于问题、数据集的形式以及用于解决特定问题的
我最近接触到 Javascript 模板并变得非常感兴趣。 我正在使用 MVC 模式构建一个大型 PHP 应用程序。模板由相当棒的 Twig 处理. 我最近遇到了一个 javascript imple
我最近在一个我要重构并拥有的项目中遇到了以下代码行: SomeClass someClass = new SomeClass(); 我这辈子都想不通为什么有人会以这种方式使用泛型。我想出的唯一原因是
亲爱的,我正在阅读这篇关于通过 asp.net 4 中的代码动态添加元标记的帖子 - 但我想问一下对 SEO 有什么好处,静态添加它或者在代码后面添加它没有问题 http://weblogs.asp.
我是一名优秀的程序员,十分优秀!