记一次Clickhouse服务不可用

本文记录了一次Clickhouse服务不可用的问题,排查过程中发现错误包括'Connection Reset By Peer'和'Socket Write Buffer'写入失败。分析表明,问题可能由未设置Socket超时的Tabix查询引起,导致缓冲区满而查询无法完成。解决方案是主动kill query以结束查询,并建议在开发clickhouse client时注意超时时间设置,防止客户端失联影响服务。

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

问题描述:

集群没有做高可用,每个分片只有一个副本。查询时无法返回结果且并没有超时错误。

 

排查:

首先看下服务器负载。磁盘使用不到50%,内存使用不到20%,cpu空闲率超过80%,各项指标都正常。

第二步看下Clickhouse server日志。err log中先后出现两种错误信息:1.Connection Reset By Peer;2.Socket Write Buffer写入失败。

尝试在服务器启用Clickhouse client进行查询,发现:

上图可以看到查询一直停留在98%。

 

原因分析:

错误1产生有以下几个原因:

1)服务器的并发连接数超过了其承载量,服务器会将其中一些连接关闭;
如果知道实际连接服务器的并发客户数没有超过服务器的承载量,则有可能是中了病毒或者木马,引起网络流量异常。可以使用netstat -an查看网络连接情况。
2)客户关掉了浏览器,而服务器还在给客户端发送数据;
3)浏览器端按了Stop;
这两种情况一般不会影响服务器。但是如果对异常信息没有特别处理,有可能在服务器的日志文件中,重复出现该异常,造成服务器日志文件过大,影响服务

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值