ClickHouse连接超时的解决方法

当使用Java通过ClickHouse官方驱动连接数据库时,可能会遇到因服务器高负载导致的延迟和超时问题。针对大量选择查询造成性能降低,简单的查询也可能运行超过30秒,进而引发JDBC驱动超时错误。解决方案是在连接URL中添加`socket_timeout`参数,例如`jdbc:clickhouse://10.100.xx.xxx:8123?socket_timeout=300000`,或者通过`ClickHouseProperties`或`Properties`设置超时时间。此方法能有效缓解ClickHouse服务器在高负载下的性能问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在通过ClickHouse官方驱动使用java代码连接数据库的时候,有时由于ClickHouse服务器在高负载下出现滞后以及ClickHouse服务器和JDBC驱动程序的超时设置不同所致。当我们有很多选择查询时,ClickHouse服务器的性能将大大降低,简单查询将运行30秒以上,从而导致JDBC驱动程序超时。
出现报错:ClickHouse exception, code: 159, host: 10.100.xx.xxx, port: 8123; Read timed out

解决方法:
在连接的路径后面加上?socket_timeout=300000
String address = “jdbc:clickhouse://10.100.xx.xxx:8123?socket_timeout=300000”;

还有如下两个方法,出自官方

ClickHouseProperties properties = new ClickhouseProperties();
properties.setSocketTimeout(timeout);
new ClickHouseDataSource(url , properties);

或者

Properties properties = new Properties();
properties.put("socket_timeout", timeout);
new ClickHouseDataSource(url, properties);

原文路径:https://blog.csdn.net/ws271/article/details/111914727

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值