不同数据库中socketTimeout作用于配置
JDBC使用socket与数据库连接,数据库并不对应用与数据库间的连接超时进行处理。
JDBC的socket timeout在数据库被突然停掉或是发生网络错误(由于设备故障等原因)时十分重要。由于TCP/IP的结构原因,socket没有办法探测到网络错误,因此应用也无法主动发现数据库连接断开。如果没有设置socket timeout的话,应用在数据库返回结果前会无期限地等下去,这种连接被称为dead connection。
os socket timeout
这个是操作系统级别的socket设置(如果jdbc socket timeout没有设置,而os级别的socket timeout有设置,则使用系统的socket timeout值)。
如果我们把socketTimeout设置如下:
socketTimeout=60000;
这意味着60秒以内服务器必须开始给客户端吐数据,以保持socket的活性。配置成60秒,一般查询都不会遇到问题。即使是全表扫描这样的大查询,数据也会流式地源源不断吐给客户端,不会达到60秒的限制。
但对于带有ORDER BY、DISTINCT、COUNT、SUM等方法的大查询,他们很可能60秒内还没有计算出结果,这时候客户端会检测到socket超时并自动断开,导致服务器会收到QUERY_KILL,中止本次执行。
socketTimeout配置方式:
jdbc:mysql://xxx.xx.xxx.xxx:3306/db_name?connectTimeout=60000&socketTimeout=60000
https://segmentfault.com/a/1190000012944562
<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close">
<!-- 设置毫秒单位的阻塞超时 -->
<property name="connectionProperties" value="oracle.net.READ_TIMEOUT=1000"/>
<!-- 其他属性设置... -->
</bean>
<property name="connectionProperties" value="socketTimeout=300000"/>
clickhouse的socket_timeout
大sql执行,会报read timed out,解决方案就是修改url,加上socket_timeout=300000
所以ck的timeout和别的数据库的timeout不一样。
https://blog.csdn.net/zero__007/article/details/51523297
原文链接:https://blog.csdn.net/maray/article/details/52127200
https://github.com/ClickHouse/clickhouse-jdbc/issues/159#issuecomment-364423414