首页 > 解决方案 > 为什么 Tombstones 会影响读取性能但不会影响更新?

问题描述

从我读到的文章中,他们说墓碑会影响 Cassandra 的读取性能。我正在阅读如何在 Cassandra 中更新数据,并且看起来数据是使用时间戳写入的,而无需修改或读取当前数据。

因此,当在压缩完成之前执行读取时,需要进行过滤以获取最新值,对吗?如果是这种情况,墓碑不是同一件事,为什么它们会对性能产生负面影响但不会更新一行?

标签: cassandracassandra-2.0cassandra-3.0

解决方案


在 Cassandra 中,update 是一个 mutation,比如 insert 和 delete,除了 LWT 的用例和一些列表操作之外,所有的 mutation 都只是追加到 memtable/commit 日志中,而不读取磁盘上的数据。所以它们非常快 - 不执行任何检查。

与此相反,读操作需要从磁盘/内存表中获取数据的所有版本,然后根据时间戳创建数据的实际版本。对于墓碑,我们需要将它们保存在内存中,因为我们可能会从磁盘中读取一些可能具有较旧时间戳的数据,我们需要对此进行检测。


推荐阅读