- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
我想知道如何以仅存储每个单元格的第一个版本的方式配置 Hbase?假设下面的 Htable:
row_key cf1:c1 timestamp
----------------------------------------
1 x t1
将 ("1","cf1:c2",t2)
放入 ColumnDescriptor.DEFAULT_VERSIONS = 2
的场景后,提到的 Htable 变为:
row_key cf1:c1 timestamp
----------------------------------------
1 x t1
1 x t2
其中 t2>t1
。
我的问题是如何改变这种情况,使第一个版本的单元格成为唯一可以存储和检索的版本。我的意思是在提供的示例中,唯一的版本是 't1'
一个!因此,我想以一种忽略重复项插入的方式更改 hbase。
我知道将 Htable 的 VERSIONS 设置为 1 并基于 Long.MAX_VALUE - System.currentTimeMillis()
放置可以解决我的问题,但我不知道它是否是最佳解决方案?!将 tstamp 更改为 Long.MAX_VALUE - System.currentTimeMillis()
有什么问题?它有任何性能问题吗?
最佳答案
我能想到的策略有两种:
将 Htable 的 VERSIONS
设置为 1 并基于 Long.MAX_VALUE - System.currentTimeMillis()
通常会工作并且没有任何重大性能问题。
写入时:
System.currentTimeMillis()
值的单元格。应该注意的是,这实际上可能不是首先尝试写入单元格的机器,因为 hbase 客户端可能不同步。 阅读时:
要通过原子性获得真正的排序,这意味着只有第一次写入到达区域服务器才会成功,您可以使用 checkAndPut
操作:
来自docs :
public boolean checkAndPut(byte[] row, byte[] family, byte[] qualifier, byte[] value, Put put) throws IOException
Atomically checks if a row/family/qualifier value matches the expected value. If it does, it adds the put. If the passed value is null, the check is for the lack of column (ie: non-existance)`
因此,通过将 value
设置为 null
,您的 Put
只有在单元格不存在时才会成功。如果您的 Put 成功,则返回值将为真。这提供了真正的原子性,但以写入性能为代价。
写入时:
Get
。一旦确认不存在,就会发出看跌期权。正如您可以想象的那样,这对每次写入都有相当大的性能影响,因为现在每次写入还涉及读取和锁定。checkAndMutate
对这些类型的checkAndPut
操作进行批处理,因为每个Put 都需要自己进行检查。这意味着每个 put 都需要是一个单独的请求,这意味着您在批量写入时也会付出延迟成本。阅读时:
如果真正的排序真的很重要,或者您可能需要在写入 hbase 之后或之前读取每一行(例如,以确定您的写入是否成功),您最好使用策略 2,否则,在所有其他情况下,我推荐策略 1,因为它的写入性能要好得多。在这种情况下,只需确保您的客户端正确时间同步即可。
关于hadoop - Hbase:只有每个单元格的第一个版本,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30681560/
我已经尝试在我的 CSS 中添加一个元素来删除每三个 div 的 margin-right。不过,似乎只是出于某种原因影响了第 3 次和第 7 次。需要它在第 3、6、9 等日工作... CSS .s
如何使 div/input 闪烁或“脉冲”?例如,假设表单字段输入了无效值? 最佳答案 使用 CSS3 类似 on this page ,您可以将脉冲效果添加到名为 error 的类中: @-webk
我目前正在尝试构建一个简单的 wireframe来自 lattice 的情节包,但由沿 y 轴的数百个点组成。这导致绘图被线框网格淹没,您看到的只是一个黑色块。我知道我可以用 col=FALSE 完全
在知道 parent>div CSS 选择器在 IE 中无法识别后,我重新编码我的 CSS 样式,例如: div#bodyMain div#paneLeft>div{/*styles here*/}
我有两个 div,一个在另一个里面。当我将鼠标悬停 到最外面的那个时,我想改变它的颜色,没问题。但是,当我将鼠标悬停 到内部时,我只想更改它的颜色。这可能吗?换句话说,当 将鼠标悬停到内部 div 上
我需要展示这样的东西 有人可以帮忙吗?我可以实现以下输出 我正在使用以下代码:: GridView.builder( scrollDirection: Axis.vertical,
当 Bottom Sheet 像 Android 键盘一样打开时,是否有任何方法可以手动上推布局( ScrollView 或回收器 View 或整个 Activity )?或者你可以说我想以 Bott
我有以下代码,用于使用纯 HTML 和 CSS 显示翻转。当您将鼠标悬停在文本上时,它会更改左右图像。 在我测试的所有浏览器中都运行良好,Safari 4 除外。据我收集的信息,Safari 4 支持
我构建了某种 CMS,但在使用 TinyMCE 和 Bootstrap 时遇到了一些问题。 我有一个页面,其中概述了一个 div,如果用户单击该 div,他们可以从模态中选择图像。该图像被插入到一个
出于某种原因,当我设置一个过渡时,当我的鼠标悬停在一个元素上时,背景会改变颜色,它只适用于一个元素,但它们都共享同一个类?任何帮助我的 CSS .outer_ad { position:rel
好吧,这真的很愚蠢。我不知道 Android Studio 中的调试监视框架发生了什么。我有 1.5.1 的工作室。 是否有一些来自 intellij 的 secret 知识来展示它。 最佳答案 与以
我有这个标记: some code > 我正在尝试获取此布局: 注意:上一个和下一个按钮靠近#player 我正在尝试这样: .nextBtn{
网站:http://avuedesigns.com/index 首页有 6 个菜单项。我希望每件元素在您经过时都有自己的颜色。 这是当您将鼠标悬停在 div 上时将所有内容更改为白色的行 li#hom
我需要在 index.php 文件中显示它,但没有任何效果。我所有的文章都没有正确定位。我将其用作代码: 最佳答案 您可以首先检查您
我是一名优秀的程序员,十分优秀!