记录clickhouse 数据库连接超时问题处理

记录clickhouse 数据库连接超时问题处理

业务场景及问题描述

业务场景: 测试环境,clickhouse 大概有3个亿的数据。业务场景:综合报表,查询一周内的报表数据统计。需要绘制的图表有接近20个,采用ForkJoin 多线程处理。数据库连接:Hikari,默认最大数据库连接数为10,连接超时时间为10s。

问题描述: 在测试环境Clickhouse有其他业务需要使用的时候,打开综合报表页面,大概率会出现数据库连接超时情况,如下图所示:

image

问题分析

首先,默认最大数据库连接数为10,数量较小(主要),连接超时时间为10s,时长偏短(次要);

其次,采用ForkJoin多线程处理,一旦有多线程同时处理且单个线程处理时间过长时,就有可能会连接数超过10,且连接超时时间超过10s,就会抛出连接超时异常。

解决办法

  • 修改最大数据库连接数,maximum-pool-size: 1000,根据环境配置以及业务需求修改成稍大的值。
  • 修改连接超时时间,connection-timeout: 10000

增加最大数据库连接数就可以解决问题,连接超时时间不用修改也可以。

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值