有了一个将TTL设置为7天的表,我希望Cassandra会在7天后删除这些行。
我的表包含布尔列,它们只在表上创建新行时将列设置为True。这些列永远不会更新为新值,因此这些列不会用新的TTL值来更改TTL值(因为Cassandra是面向列的数据库)。
但是,我注意到,7天后,所有列都被设置为空值(预期将被删除),除了那些保持为True的布尔列之外,因此,这些行永远不会被删除。检查所有列的TTL值,它们有空值,这意味着TTL已过期在所有列上,包括布尔列。
当手动将布尔列设置为NULL时(7天之后),行将按预期立即移除。
我不明白为什么Cassandra在TTL过期后不将布尔列设置为NULL,因此行将自动删除。Cassandra是否以不同的方式与布尔列和TTL值一起工作?
与以下方面合作:
发布于 2019-08-28 09:22:06
解决方案:运行nodetool flush后,问题得到修复,并在TTL过期时删除行。
这真的很奇怪,但它正在工作,我可以看到行立即被删除。我找不到不删除表中过期行的原因,即使这些行已在马厩上标记为过期(expires= true)。
https://stackoverflow.com/questions/57491220
复制相似问题