2.Clickhouse常见配置解析

Clickhouse常见配置解析

  Clickhouse的常见配置项在config.xml或 usesr.xml中,基本上都在users.xml中。
  下面为ck官网中的配置页     
  • config.xml 的配置项
    https://clickhouse.tech/docs/en/operations/server-configuration-parameters/settings/
  • users.xml的配置项
    https://clickhouse.com/docs/en/operations/settings/settings/

CPU资源

配置描述
background_pool_size后台线程池的大小,merge线程就是在该线程池中执行,该线程池不仅仅是给merge线程用的,默认值是16,允许的前提下建议改成 cpu 个数的2倍( 线程数
background_schedule_pool_size执行后台任务(复制表、 kafka流 、DNS 缓存更新) 的线程数。默认 128, 建议改成 cpu 的 2 倍。
background_distributed_schedule_pool_size设置为分布式发送执行后台任务的线程数, 默认 6 ,建议改成 CPU 个数的 2 倍(线程数)
max_concurrent_queries最大并发处理的请求数(包含 select,insert等 ),默认值 100 ,推荐 150(不够再加)~ 300 。
max_thread设置单个查询所能使用的最大 CPU 个数,默认是CPU 核数。

内存资源

配置描述
max_memory_usage此参数在 users.xml 中,表示单次 Query 占用内存最大值,该值可以设置的比较大,这样可以提升集群查询的上限。
max_bytes_before_external_group_by一般哪找max_memory_useage 的一般设置内存, 当group 使用内存超过阈值后会刷新到磁盘进行 。因为clickhouse 聚合分两个阶段:查询并建立中间数据、合并中间数据,结合上一项,建议50G
max_bytes_before_external_sort当order by 已使用 max_bytes_before_external_sort 内存就进行溢出写磁盘(基于磁盘排序),如果不设置该值,那么当内存不够时直接跑错,设置了该值 order by 可以正常完成,但是速度相对内存来说肯定要慢点(实测慢的非常多,无法接受)。
max_table_size_to_drop此参数在config.xml 中,应用于需要删除表或分区的情况,默认是50GB,意思是如果删除50GB以上的分区表会失败。建议修改为0 ,这样不管多大的分区表都可以删除。
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值