PolarDB设置了net_write_timeout也不行,为啥客户端工具就不会超时,jdbc代码里面链接就会超时呢?
PolarDB客户端工具和JDBC代码中的连接超时设置可能不同,这取决于具体的实现方式。
在PolarDB客户端工具中,超时设置通常是通过命令行参数或配置文件来控制的。例如,在使用mysql
命令连接到PolarDB时,可以使用--connect-timeout
参数来设置连接超时时间。
而在JDBC代码中,超时设置通常是通过Statement
对象的setQueryTimeout
方法来设置的。这个方法接受一个整数参数,表示查询超时时间(以秒为单位)。
需要注意的是,这两种方式的超时设置可能会受到网络环境、服务器性能等因素的影响。如果在实际使用中遇到连接超时问题,可以尝试调整这些设置的值,或者检查网络连接是否正常。
这种从我们之前处理的经验有可能是jdbc在处理数据量多的时候,可能会gc,导致数据堆积在tcp队列里,然后keepalive超时。客户端工具没有gc的问题,只要处理的够快就不会在tcp队列里堆积。此回答整理自钉群“PolarDB 专家面对面 - 网络&连接&线程池功能”
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。
PolarDB 分布式版 (PolarDB for Xscale,简称“PolarDB-X”) 采用 Shared-nothing 与存储计算分离架构,支持水平扩展、分布式事务、混合负载等能力,100%兼容MySQL。 2021年开源,开源历程及更多信息访问:OpenPolarDB.com/about