【clickhouse】1、运维, sql, 性能, go client

一 运维

官网安装文档

1.1 启动

  • 命令行连接
/etc/init.d/clickhouse-server start
clickhouse-client -m -h 192.168.2.99 --port 9999 -u default --password mypass
  • 建表
use default;
SET allow_suspicious_low_cardinality_types = 1;

CREATE TABLE default.tb
(
    id                     		LowCardinality(Int64),
    ts                          DateTime64(3),
    gas_station_code            LowCardinality(String),
    aid			                UUID,
    type_id                     UInt32
)ENGINE = MergeTree
    PARTITION BY toYYYYMMDD ( ts )
    ORDER BY
(
    ts,
    id
)
    TTL toDateTime(ts) + toIntervalMonth(6)
    SETTINGS index_granularity = 8192;

ALTER TABLE tb MODIFY TTL toDateTime(ts) + toIntervalMonth(6);
  • 执行sql文件
clickhouse-client --user default --password mypass -d default --multiquery -h 192.168.2.99 --port 9999 < c.sql

二 sql

alter table tb delete where 1; -- 删除

三 性能

一、优点:
1.为了高效的使用CPU,数据不仅仅按列存储,同时还按向量进行处理;
2.数据压缩空间大,减少IO;处理单查询高吞吐量每台服务器每秒最多数十亿行;
3.索引非B树结构,不需要满足最左原则;只要过滤条件在索引列中包含即可;即使在使用的数据不在索引中,由于各种并行处理机制ClickHouse全表扫描的速度也很快;
4.写入速度非常快,50-200M/s,对于大量的数据更新非常适用。

二、缺点:
1.不支持事务,不支持真正的删除/更新;
2.不支持高并发,官方建议qps为100,可以通过修改配置文件增加连接数,但是在服务器足够好的情况下;
3.SQL满足日常使用80%以上的语法,join写法比较特殊;最新版已支持类似SQL的join,但性能不好;
4.尽量做1000条以上批量的写入,避免逐行insert或小批量的insert,update,delete操作,因为ClickHouse底层会不断的做异步的数据合并,会影响查询性能,这个在做实时数据写入的时候要尽量避开;
5.Clickhouse快是因为采用了并行处理机制,即使一个查询,也会用服务器一半的CPU去执行,所以ClickHouse不能支持高并发的使用场景,默认单查询使用CPU核数为服务器核数的一半,安装时会自动识别服务器核数,可以通过配置文件修改该参数。
全量数据导入:数据导入临时表 -> 导入完成后,将原表改名为tmp1 -> 将临时表改名为正式表 -> 删除原表
增量数据导入: 增量数据导入临时表 -> 将原数据除增量外的也导入临时表 -> 导入完成后,将原表改名为tmp1-> 将临时表改成正式表-> 删除原数据表

三、优化:
1.关闭虚拟内存,物理内存和虚拟内存的数据交换,会导致查询变慢。
2.为每一个账户添加join_use_nulls配置,左表中的一条记录在右表中不存在,右表的相应字段会返回该字段相应数据类型的默认值,而不是标准SQL中的Null值。
3.JOIN操作时一定要把数据量小的表放在右边,ClickHouse中无论是Left Join 、Right Join还是Inner Join永远都是拿着右表中的每一条记录到左表中查找该记录是否存在,所以右表必须是小表。
4.批量写入数据时,必须控制每个批次的数据中涉及到的分区的数量,在写入之前最好对需要导入的数据进行排序。无序的数据或者涉及的分区太多,会导致ClickHouse无法及时对新导入的数据进行合并,从而影响查询性能。
5.尽量减少JOIN时的左右表的数据量,必要时可以提前对某张表进行聚合操作,减少数据条数。有些时候,先GROUP BY再JOIN比先JOIN再GROUP BY查询时间更短。
6.ClickHouse的分布式表性能性价比不如物理表高,建表分区字段值不宜过多,防止数据导入过程磁盘可能会被打满。
7.CPU一般在50%左右会出现查询波动,达到70%会出现大范围的查询超时,CPU是最关键的指标,要非常关注。

四、性能情况:
1.单个查询吞吐量:如果数据被放置在page cache中,则一个不太复杂的查询在单个服务器上大约能够以2-10GB/s(未压缩)的速度进行处理(对于简单的查询,速度可以达到30GB/s)。如果数据没有在page cache中的话,那么速度将取决于你的磁盘系统和数据的压缩率。例如,如果一个磁盘允许以400MB/s的速度读取数据,并且数据压缩率是3,则数据的处理速度为1.2GB/s。这意味着,如果你是在提取一个10字节的列,那么它的处理速度大约是1-2亿行每秒。对于分布式处理,处理速度几乎是线性扩展的,但这受限于聚合或排序的结果不是那么大的情况下。
2.处理短查询的延时时间:数据被page cache缓存的情况下,它的延迟应该小于50毫秒(最佳情况下应该小于10毫秒)。 否则,延迟取决于数据的查找次数。延迟可以通过以下公式计算得知: 查找时间(10 ms) * 查询的列的数量 * 查询的数据块的数量。
3.处理大量短查询:ClickHouse可以在单个服务器上每秒处理数百个查询(在最佳的情况下最多可以处理数千个)。但是由于这不适用于分析型场景。建议每秒最多查询100次。
4.数据写入性能:建议每次写入不少于1000行的批量写入,或每秒不超过一个写入请求。当使用tab-separated格式将一份数据写入到MergeTree表中时,写入速度大约为50到200MB/s。如果您写入的数据每行为1Kb,那么写入的速度为50,000到200,000行每秒。如果您的行更小,那么写入速度将更高。为了提高写入性能,您可以使用多个INSERT进行并行写入,这将带来线性的性能提升。
count: 千万级别,500毫秒,1亿 800毫秒 2亿 900毫秒 3亿 1.1秒
group: 百万级别 200毫米,千万 1秒,1亿 10秒,2亿 20秒,3亿 30秒
join:千万-10万 600 毫秒, 千万 -百万:10秒,千万-千万 150秒
ClickHouse并非无所不能,查询语句需要不断的调优,可能与查询条件有关,不同的查询条件表是左join还是右join也是很有讲究的。

五、其他:
1.MySQL单条SQL是单线程的,只能跑满一个core,ClickHouse相反,有多少CPU,吃多少资源,所以飞快;
2.ClickHouse不支持事务,不存在隔离级别。ClickHouse的定位是分析性数据库,而不是严格的关系型数据库。
3.IO方面,MySQL是行存储,ClickHouse是列存储,后者在count()这类操作天然有优势,同时,在IO方面,MySQL需要大量随机IO,ClickHouse基本是顺序IO。
有人可能觉得上面的数据导入的时候,数据肯定缓存在内存里了,这个的确,但是ClickHouse基本上是顺序IO。对IO基本没有太高要求,当然,磁盘越快,上层处理越快,但是99%的情况是,CPU先跑满了(数据库里太少见了,大多数都是IO不够用)。

四 go clinet

官方有两个 go client

  • clickhouse-go - High level language client which supports either the Go standard database/sql interface or the native interface.
  • ch-go - Low level client. Native interface only.

Clickhouse-Go提供了一个高级界面,允许用户使用面向行的语义和批处理来查询和插入数据,这些语义和批处理对数据类型很宽松-如果不会潜在地导致精度损失,值将被转换。同时,CH-GO提供了优化的面向列的接口,该接口以较低的CPU和内存开销提供快速数据块流,但代价是类型严格性和更复杂的使用。

从2.3版开始,Clickhouse-Go将ch-go用于低级功能,如编码、解码和压缩。请注意,Clickhouse-Go还支持Go数据库/SQL接口标准。两个客户端都使用本机格式进行编码,以提供最佳性能,并且可以通过本机ClickHouse协议进行通信。Clickhouse-Go还支持将HTTP作为其传输机制,用于用户需要代理或负载平衡流量的情况。

选择 client:
选择客户端库取决于您的使用模式和对最佳性能的需求。对于插入量大的用例,每秒需要数百万次插入,我们建议使用低级别客户端ch-go。这个客户机避免了将数据从面向行的格式转换为列的相关开销,而ClickHouse本机格式需要这样做。此外,它避免了任何接口{}(any)类型的反射或使用,以简化使用。

对于专注于聚合或吞吐量较低的插入工作负载的查询工作负载,Clickhouse-Go提供了熟悉的数据库/SQL界面和更直接的行语义。用户还可以选择将HTTP用于传输协议,并利用帮助器函数将行封送到结构或从结构封送行。

The clickhouse-go Client

The clickhouse-go client provides two API interfaces for communicating with ClickHouse:

  • ClickHouse client-specific API
  • database/sql standard - generic interface around SQL databases provided by Golang.
  • 21
    点赞
  • 18
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

呆呆的猫

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

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

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

打赏作者

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

抵扣说明:

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

余额充值