首页 > 其他分享 >ClickHouse 的 Mutations

ClickHouse 的 Mutations

时间:2024-10-15 10:43:45浏览次数:1  
标签:Mutations 查询 mutations 使用 数据 ALTER ClickHouse

mutations

ALTER 查询是通过一种称为 "mutations" 的机制实现的,其中最常见的是 ALTER TABLE ... DELETE 和 ALTER TABLE ... UPDATE。它们是在后台异步进行的,类似于 MergeTree 表中的合并。

 

对于 *MergeTree 表,mutations 是通过重写所有的 part 来执行的。mutations 不具有原子性。

 

mutations 完全是按照 part 的创建顺序进行应用的。会部分按照 INSERT INTO 查询的顺序:mutations 之前插入表中的数据将被应用,而在此之后插入的数据将不会被应用。请注意,mutations 不会以任何方式阻止插入。

 

添加 mutations 条目后,mutations 查询会立即返回。mutations 本身使用系统配置文件设置异步执行。可以使用 system.mutations 表跟踪进度。即使重新启动 ClickHouse 服务器,已成功提交的 mutations 仍将继续执行。mutations 一旦提交,就无法回滚,但如果因某种原因卡住,可以使用 KILL MUTATION 命令来取消。

 

已完成的 mutations 条目不会立即删除(保留条目的数量由 finished_mutations_to_keep 存储引擎参数决定)。较旧的突变条目会被删除。

 

ClickHouse 支持 mutations 频率较高的操作,并提供多种功能来帮助用户管理这些操作。例如,推荐的用于时间序列数据的 MergeTree 引擎内置了重复数据删除和版本控制功能。这意味着你可以在不覆盖现有数据的情况下插入新数据,避免 mutations 并保留历史数据。此外,ClickHouse 还提供版本管理功能,允许你保留同一行的多个版本,这样你就可以在不覆盖现有数据的情况下插入新数据。

ALTER 查询的同步性

对于非复制表,所有 ALTER 查询都是同步执行的。对于复制表,查询只是向 ZooKeeper 添加相应操作的指令,操作本身会尽快执行。不过,ALTER 查询可以等待这些操作在所有复制表上完成。

 

对于创建 mutations的 ALTER 查询(例如:包括但不限于 UPDATE、DELETE、MATERIALIZE INDEX、MATERIALIZE PROJECTION、MATERIALIZE COLUMN、APPLY DELETED MASK、CLEAR STATISTIC、MATERIALIZE STATISTIC),同步性由 mutations_sync 设置来定义。

 

对于其他只修改元数据的 ALTER 查询,可以使用 alter_sync 设置来设置等待。

 

通过 replication_wait_for_inactive_replica_timeout 设置,可以指定等待非活动副本执行所有 ALTER 查询的时间(以秒为单位)。

 

注意

对于所有 ALTER 查询,如果 alter_sync = 2,且某些副本未活跃的时间超过 replication_wait_for_inactive_replica_timeout 设置中指定的时间,则会出现 UNFINISHED 异常。

 

表的mutations 是并行还是串行

ClickHouse 按顺序运行 mutations,但它可以将多个 mutations 合并为一个,并在一次合并中应用所有mutations。有时,当 ClickHouse 需要执行的合并表达式变得非常大时,这可能会导致问题(如果 ClickHouse 将数千个 mutations 合并在一个表达式中)。

 

由于 ClickHouse 将数据存储在独立的 part 中,因此 ClickHouse 能够为每个 part 独立并行运行 mutations 合并。如果你在 mutations 中使用 x IN (SELECT ... FROM big_table)语句,这也会导致资源利用很高,尤其是内存使用率,因为每次合并都会运行并在内存中保留其自己的 HashSet。如果在这种mutations中使用字典方法,就可以避免这个问题。

 

并行控制的参数设置:

SELECT name,value,description
FROM system.merge_tree_settings
WHERE name LIKE '%mutation%'

┌─name──────────────────────────────────────────────────────┌─value──────┬─description────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────┐
│ max_replicated_mutations_in_queue                         │ 8          │ How many tasks of mutating parts are allowed simultaneously in ReplicatedMergeTree queue.                                                                                                      │
│ number_of_free_entries_in_pool_to_execute_mutation        │ 20         │ When there is less than specified number of free entries in pool, do not execute part mutations. This is to leave free threads for regular merges and avoid "Too many parts"                   │
│ max_number_of_mutations_for_replica                       │ 0          │ Limit the number of part mutations per replica to the specified amount. Zero means no limit on the number of mutations per replica (the execution can still be constrained by other settings). │
│ replicated_max_mutations_in_one_entry                     │ 10000      │ Max number of mutation commands that can be merged together and executed in one MUTATE_PART entry (0 means unlimited)                                                                          │
│ number_of_mutations_to_delay                              │ 500        │ If table has at least that many unfinished mutations, artificially slow down mutations of table. Disabled if set to 0                                                                          │
│ number_of_mutations_to_throw                              │ 1000       │ If table has at least that many unfinished mutations, throw 'Too many mutations' exception. Disabled if set to 0                                                                               │
│ finished_mutations_to_keep                                │ 100        │ How many records about mutations that are done to keep. If zero, then keep all of them.                                                                                                        │
│ zero_copy_merge_mutation_min_parts_size_sleep_before_lock │ 1073741824 │ If zero copy replication is enabled sleep random amount of time before trying to lock depending on parts size for merge or mutation                                                            │
└───────────────────────────────────────────────────────────└────────────┴────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────┘

 

监控mutations

整个过程是异步的,有可能会花费很长的时间。也可能会遇到错误,并阻塞后面的 mutations。因此,很有必要监控它,从而决定是取消还是重新应用。尤其是表上有很多 ALTER、UPDATE的时候。

 

监控是通过查询表 system.mutations 实现的。每个mutation 会在表中产生一条记录。

 

比如,如果有大量的 mutations 在执行的时候,可以通过以下语句查看数量:

SELECT
   hostname() AS host,
   count()
   FROM clusterAllReplicas('default', 'system.mutations') WHERE not is_done
   GROUP BY host;

查看是否有错误发生:

SELECT
    hostname() AS host,
    count()
FROM clusterAllReplicas('default', 'system.mutations')
WHERE (latest_fail_reason <> '' OR toUInt64(latest_fail_time) <> 0)
GROUP BY host

查看正在运行的 mutations:

SELECT
    hostname() AS host,
    count()
FROM clusterAllReplicas('default', 'system.mutations')
WHERE is_done = 0 AND create_time < now() - INTERVAL 24 HOUR
GROUP BY host

以上查询都是假设,你的集群名称是 default。如果不是,需要修改成自己的集群名称。如果要想确认是否所有的节点都已成功结束,需要在每个节点单独执行查询。因为表 system.mutations 是本地表。

 

如果没有集群,可以使用以下的查询:

SELECT
   hostname() AS host,
   count()
   FROM system.mutations WHERE not is_done
   GROUP BY host;

 

如何避免 mutations

1.使用适当的数据模型: 确保有一个设计良好的数据模型,将数据分隔成适当的表和列。这将有助于防止数据意外 mutations。

2.使用只读用户: 如果需要只允许某些用户读取数据,可以使用只读用户来避免意外 mutations。该用户只能选择数据,但不能更新、删除或插入数据。

3.使用 modify_date_column_name 设置: 在执行可能会更新数据的查询时,可以使用 modify_date_column_name 查询显式设置时间戳列,该列将以当前时间更新。

4.使用 FINAL 关键字:在创建表时,可以使用 FINAL 关键字来阻止对表定义的任何进一步修改,这将有助于避免任何意外 mutations。

5.使用 MergeTree 引擎:

在处理时间序列数据或需要避免 mutations 时,建议使用 MergeTree 引擎,该引擎内置重复数据删除和版本控制功能,这意味着插入新数据时无需覆盖现有数据。

6.使用版本管理功能: ClickHouse 具有版本控制功能,允许你保留同一行的多个版本,这意味着你可以在不覆盖现有数据的情况下插入新数据,这将帮助你避免意外mutations。

7.使用只读属性:如果想防止特定表发生意外 mutations,可以使用 readonly 属性将表设置为只读,这将防止对该表进行任何更新、删除或插入操作。

8.使用数据库触发器:可以使用数据库触发器来防止某些 mutations 的发生,例如,可以使用触发器来防止对特定表进行删除操作。

标签:Mutations,查询,mutations,使用,数据,ALTER,ClickHouse
From: https://www.cnblogs.com/abclife/p/18458118

相关文章

  • 深入解析ClickHouse:优势、架构、数据组织与应用场景
    引言在大数据时代,随着数据量的不断增长,越来越多的企业需要高效的数据分析工具来支持实时决策。ClickHouse作为一款高性能的列式数据库,因其在实时分析处理方面的卓越表现,逐渐在数据仓库领域脱颖而出。本篇博客将对ClickHouse进行深入解析,全面介绍其优势、数据架构、数据组织方......
  • ClickHouse 数据保护指南:从备份到迁移的全流程攻略
    一、背景运行3年的clickhouse需要迁移机房,迁移单库单表的140亿条的数据。采用clickhouse-backup的方式进行备份迁移,打包备份,再加上数据拷贝,数据恢复一共花费30分钟。数据在一定量级,避免使用SQL导入导出的方式,效率太低二、clickhouse-backup工具介绍clickhouse-back......
  • 大数据新视界 --大数据大厂之 ClickHouse:大数据分析领域的璀璨明星
           ......
  • 【ClickHouse 表引擎&SQL操作&副本&分片集群 02】
    一、表引擎表引擎决定了如何存储表的数据。类似mysql的引擎InnoDB,MyISAM数据的存储方式和位置,写到哪里以及从哪里读取数据一般的引擎都存储在本地的磁盘,clickhouse存储的位置在:/var/lib/clickhouse -->其中data存储数据,metadata存储建表语句支持那些查询以及如何支持并......
  • ClickHouse性能调优 - 当磁盘IO是瓶颈的时候
    引言ClickHouse的性能调优问题是一个大的话题。虽然ClickHouse以其高速的数据处理能力而闻名,但在实际使用中,磁盘IO常常成为影响系统性能的瓶颈。本文将探讨在磁盘IO成为瓶颈时,如何通过一系列优化措施来提升ClickHouse的整体性能。磁盘IO瓶颈磁盘IO瓶颈指的是在数据读写过程中,磁......
  • 【ClickHouse 特点&数据类型&表引擎&SQL操作&副本&分片集群 01】
    概念:ClickHouse是开源的列式存储数据库(DBMS),使用C++语言编写,主要用于在线分析处理查询(OLAP),能够使用SQL查询实时生成分析数据报告OLAP这样的适合做一些一次插入多次查询这样的操作(适合查询),对于新增更新删除就不太擅长了,所以ClickHouse是一种分析性数据库HBase也是列式存储......
  • [Clickhouse] Clickhouse 特性 : WITH FILL(缺失段数据补齐)
    1背景引入背景需求:缺失数据的补齐要聚合查询一些数据,按照时间15分钟聚合数据量或根据用户提供的入参startTime/endTime动态筛选指定的若干月份聚合数据。但是由于某些时间段(如:某些月份)数据缺失,一些时段值没有,前端显示就会有问题,需要数据接口开发者自己插值解决有一种实......
  • [clickhouse] Clickhouse 关键特性的版本支持与演变
    clickhouse21.10Feature:UDF用户可通过添加lambda表达式,创建自定义FunctionCREATEFUNCTIONlinear_equationAS(x,k,b)->k*x+b;SELECTnumber,linear_equation(number,2,1)FROMnumbers(3);CREATEFUNCTIONparity_strAS(n)->if(n%2,'odd',&......
  • ClickHouse、Doris、 Impala等MPP架构详解
    我们常用的大数据计算引擎有很多都是MPP架构的,像我们熟悉的Impala、ClickHouse、Druid、Doris等都是MPP架构。采用MPP架构的很多OLAP引擎号称:亿级秒开。本文分为三部分讲解,第一部分详解MPP架构,第二部分剖析MPP架构与批处理架构的异同点,第三部分是采用MPP架构的OLAP引擎介绍。......
  • 题解 ARC118E【Avoid Permutations】/ SS240928D【d】
    题目描述对于一个排列\(a\),定义其权值如下:生成一个\((n+2)\times(n+2)\)的网格图,行列标号为\(0∼n+1\),每次可以从\((i,j)\)走到\((i,j+1)\)或\((i+1,j)\),且不能走到\((i,a_i)\),权值为从\((0,0)\)走到\((n+1,n+1)\)的方案数。现在排列\(......