- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
从 Cassandra 文档的两个不同链接中,我发现:
link 1
A structure stored in memory that checks if row data exists in the memtable before accessing SSTables on disk
Cassandra checks the Bloom filter to discover which SSTables are likely to have the request partition data.
最佳答案
Bloom filter是用于检查元素是否存在于集合中的通用数据结构。它的算法设计得非常快,代价是冒着返回误报的风险。
Cassandra 使用布隆过滤器来测试是否有任何 SSTable 可能包含请求的分区键,而无需实际读取它们的内容(从而避免昂贵的 IO 操作)。
如果布隆过滤器返回 false
对于给定的分区键,则绝对可以肯定该分区键不存在于相应的 SSTable 中;如果它返回 true
,但是,那么 SSTable 很可能包含分区键。发生这种情况时,Cassandra 将采用更复杂的技术来确定是否需要读取该 SSTable。请注意,大多数读取都会引用布隆过滤器,并且仅在某些写入期间(当内存表刷新到磁盘时)进行更新。您可以阅读更多关于 Cassandra 的读取路径 here .
回到你的问题:
1)第一条语句(“存储在内存中的结构,在访问磁盘上的SSTables之前检查memtable中是否存在行数据”)恕我直言不准确:当memtable刷新到磁盘时确实会更新布隆过滤器,但它们没有引用内存表。
2) 每个 SSTable 维护布隆过滤器,即磁盘上的每个 SSTable 在内存中都有一个相应的布隆过滤器。
关于cassandra - 布隆过滤器在 cassandra 中的作用是什么?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39327427/
今天有小伙伴给我留言问到,try{...}catch(){...}是什么意思?它用来干什么? 简单的说 他们是用来捕获异常的 下面我们通过一个例子来详细讲解下
我正在努力提高网站的可访问性,但我不知道如何在页脚中标记社交媒体链接列表。这些链接指向我在 facecook、twitter 等上的帐户。我不想用 role="navigation" 标记这些链接,因
说现在是 6 点,我有一个 Timer 并在 10 点安排了一个 TimerTask。之后,System DateTime 被其他服务(例如 ntp)调整为 9 点钟。我仍然希望我的 TimerTas
就目前而言,这个问题不适合我们的问答形式。我们希望答案得到事实、引用资料或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the
我就废话不多说了,大家还是直接看代码吧~ ? 1
Maven系列1 1.什么是Maven? Maven是一个项目管理工具,它包含了一个对象模型。一组标准集合,一个依赖管理系统。和用来运行定义在生命周期阶段中插件目标和逻辑。 核心功能 Mav
我是一名优秀的程序员,十分优秀!