ClickHouse的数据一致性(七)

22 篇文章 0 订阅
14 篇文章 4 订阅

数据一致性的方案

查询 CK 手册发现,即便对数据一致性支持最好的 Mergetree,也只是保证最终一致性:

  • 1手动使用OPTIMIZE
  • 2 通过 Group by 去重
  • 3 通过 FINAL 查询

我们在使用 ReplacingMergeTree、SummingMergeTree 这类表引擎的时候,会出现短暂
数据不一致的情况。在某些对一致性非常敏感的场景,通常有以下几种解决方案。

1 手动使用OPTIMIZE(强烈不建议生产上使用)

在写入数据后,立刻执行 OPTIMIZE 强制触发新写入分区的合并动作。

OPTIMIZE TABLE table_name FINAL;

语法:OPTIMIZE TABLE [db.]name [ON CLUSTER cluster] [PARTITION partition | PARTITION ID 'partition_id'] [FINAL] [DEDUPLICATE [BY expression]]

2 通过 Group by 去重

此方法通常需要在创建表时,添加删除标识字段:比如is_deleted,默认为0,0代表未删除,1代表已删除;并且需要以时间为索引进行order by排序。

(1)执行去重的查询

SELECT
	user_id ,
  	argMax(score, create_time) AS score,
  	argMax(is_deleted, create_time) AS deleted,
  	max(create_time) AS ctime
FROM test_a
GROUP BY user_id
HAVING deleted = 0;

函数说明:

argMax(field1,field2):按照 field2 的最大值取 field1 的值。当我们更新数据时,会写入一行新的数据,例如上面语句中,通过查询最大的create_time 得到修改后的 score 字段值。

注意:ClickHouse并不能很好的支持事务型数据的删除,但是可以通过其他策略支持删除,比如is_deleted字段来支持数据,如果将某user_id删除,即将某user_id对应的is_deleted置为1。

然而,这行数据并没有被真正的删除,而是被过滤掉了。在一些合适的场景下,也可以结合表级别的TTL 最终将物理数据删除。

3 通过 FINAL 查询

在查询语句后增加 FINAL 修饰符,这样在查询的过程中将会执行 Merge 的特殊逻辑(例 如数据去重,预聚合等)。

但是这种方法在早期版本基本没有人使用,因为在增加 FINAL 之后,我们的查询将会变 成一个单线程的执行过程,查询速度非常慢。

在 v20.5.2.7-stable 版本中,FINAL 查询支持多线程执行,并且可以通过 max_final_threads 参数控制单个查询的线程数。但是目前读取 part 部分的动作依然是串行的。

FINAL 查询最终的性能和很多因素相关,列字段的大小、分区的数量等等都会影响到最 终的查询时间,所以还要结合实际场景取舍。

参考链接https://github.com/ClickHouse/ClickHouse/pull/10463

本文作者:好名字
原文链接:https://www.cuizb.top/myblog/article/1639988535
版权声明: 本博客所有文章除特别声明外,均采用 CC BY 3.0 CN协议进行许可。转载请署名作者且注明文章出处。

更多文章和干货请关注公众号

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
ClickHouse 是一个列式数据库管理系统,用于存储和处理大规模数据。在写入 ClickHouse 数据时,可能会涉及到数据一致性问题。 ClickHouse 默认情况下是可扩展的,它使用主从复制机制提供高可用性。在数据写入时,首先将数据写入主节点,然后主节点将数据进行复制并同步到所有从节点上。这确保了数据的冗余备份和高可用性。 然而,由于主从复制需要一定的时间,从节点可能会稍有延迟。因此,从节点上的数据可能会略微滞后于主节点上的数据。这意味着当数据写入完成后,立刻从从节点上查询可能无法得到最新的结果。 为了解决这一问题,ClickHouse 提供了两个级别的一致性保证: 1. 弱一致性(Eventual Consistency):这是 ClickHouse 的默认行为。在写入后的瞬间,从节点可能会滞后于主节点,但之后它们会趋向于一致。这种滞后是由于数据在网络上的传输延迟造成的。这种弱一致性可以满足大多数应用场景的需求,尤其是大规模数据分析和实时报表生成。 2. 强一致性(Strong Consistency):ClickHouse 也提供了强一致性的选项,可以通过配置来确保主节点和从节点的数据保持一致。使用这种模式会引入一定的性能开销,因为主节点会在每次写入操作完成后等待所有从节点进行数据复制和同步。 在实际应用中,根据具体的业务需求和对数据一致性的要求,可以选择适合的一致性级别。弱一致性ClickHouse 的默认模式,适用于大多数场景。而如果对数据实时一致性和精确性要求很高,可以选择强一致性模式。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Java技术债务

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值