故障切换导致现在程序链接数据库超时,Polardb这个报错怎么解决 ?
The last packet successfully received from the server was 3,011 milliseconds ago. The last packet sent successfully to the server was 3,012 milliseconds ago.
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。
根据您提供的报错信息:
The last packet successfully received from the server was 3,011 milliseconds ago. The last packet sent successfully to the server was 3,012 milliseconds ago.
此错误表明程序与PolarDB数据库之间的连接在指定时间内未收到响应,导致超时。结合知识库中的参考资料,此类问题通常由以下原因引起: 1. 连接池配置问题:程序侧的连接池可能未正确设置超时参数。 2. RDS主备切换后连接池脏连接问题:RDS主备切换后,PolarDB-X 1.0的连接池中可能存在未感知到的脏连接。 3. 网络或防火墙问题:程序所在环境的网络配置可能导致连接中断。 4. 事务超时或SQL执行时间过长:事务或查询的执行时间超出限制。
socketTimeout
、connectTimeout
等)。如果未设置或值过小,建议调整为更大的值。SHOW VARIABLES LIKE '%timeout%';
根据返回结果,确认是否存在不合理的超时限制,并在程序侧进行相应调整。
socket_timeout
参数调大(例如设置为900秒以上),以触发PolarDB-X 1.0重建连接池。curl ifconfig.me
curl ip.me
0.0.0.0/0
添加至白名单,成功连接后执行以下命令获取真实公网IP:
SHOW PROCESSLIST;
获取真实IP后,将其加入白名单,并删除0.0.0.0/0
。
SET drds_transaction_timeout = <新值>;
单位为毫秒,建议根据实际业务需求设置合理的值。 - 检查查询超时时间限制: - PolarDB 5.6:
SHOW GLOBAL VARIABLES LIKE '%max_statement_time%';
SHOW GLOBAL VARIABLES LIKE '%max_execution_time%';
如果返回值非0,表示存在查询超时限制,可以在参数设置中将值调大。
通过以上步骤,您可以逐步排查并解决程序链接PolarDB数据库超时的问题。您可以复制页面截图提供更多信息,我可以进一步帮您分析问题原因。
阿里云关系型数据库主要有以下几种:RDS MySQL版、RDS PostgreSQL 版、RDS SQL Server 版、PolarDB MySQL版、PolarDB PostgreSQL 版、PolarDB分布式版 。