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

标签 postgresql spring-boot kubernetes spring-data-jpa

我在 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/

相关文章:

python - Airflow - ModuleNotFoundError : No module named 'kubernetes'

java - 或 sql 查询在 java 系统中不起作用-在列中搜索数据

mongodb - 公开一个 Java Spring Boot 方法

kubernetes - 为什么kubectl描述 secret 不起作用?

java - 使用 docker 容器中的 java 访问类路径中的 JSON 文件时遇到 FileNotFoundException(SprintBootApplication)

java - org.springframework.beans.factory.UnsatisfiedDependencyException : Error creating bean with name 'demoRestController'

Kubernetes calico 节点 CrashLoopBackOff

sql - 在 where 子句中使用数组函数

arrays - 从 postgres 数组中删除重叠条目

java - Tomcat 服务器声明我的 PostgreSQL 数据库不存在,但它确实存在