gpt4 book ai didi

postgresql - 在 kubernetes pod 被杀死后释放 JDBC 连接

转载 作者:行者123 更新时间:2023-12-02 12:37:09 37 4
gpt4 key购买 nike

我在 Kubernetes 中运行了几个 Spring Boot 应用程序。每个应用程序都使用 spring JPA 连接到 Postgresql 10.6 数据库。我注意到的是,当 Pod 被意外杀死时,与数据库的连接没有被释放。

运行SELECT sum(numbackends) FROM pg_stat_database;在数据库上返回让我们说 50,在杀死几个运行 spring 应用程序并重新运行查询的 pod 后,这个数字跳到 60,这最终导致与 postgresql 的连接数超过最大值并阻止重新启动的 pod 的应用程序连接到数据库.

我已经尝试过使用 postgresql 选项 idle_in_transaction_session_timeout将其设置为 15 秒,但这不会丢弃旧连接,并且数量会不断增加。

我正在使用 com.zaxxer.hikari.HikariDataSource我的 spring 应用程序的数据源,想知道是否有办法防止这种情况发生,无论是在 posgresql 还是 spring boot 方面。

欢迎任何建议或建议。

Spring 启动版本:2.0.3.RELEASE
Java版本:1.8
PostgreSQL 版本 10.6

最佳答案

这个问题不仅会出现在 kubernetes pod 上,而且还会出现在服务器上运行的简单应用程序被强制终止(如 Linux 上的 kill -9 pid)并且没有机会通过关闭 Hook 进行清理以进行 Spring 启动。我认为在这种情况下,应用程序方面没有任何帮助。但是,您可以尝试通过数据库端的几种方法清理非事件连接,如 here 所述。 .

关于postgresql - 在 kubernetes pod 被杀死后释放 JDBC 连接,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54958870/

37 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com