Pgbouncer 优雅终止因插入删除而退出

问题描述

我们有一个 Postgres 和 PgBouncer 设置,并根据 pgbouncer 文档使用 SIGINT 进行优雅终止:

信号情报 安全关机。与在控制台上发出 PAUSE 和 SHUTDOWN 相同。

预停止钩子脚本如下所示:

kill -INT 1; sleep 270;

但 pgbouncer 有时无法及时退出,一些插入和其他可能的命令被丢弃导致数据完整性问题。

有谁知道调试这个的好方法吗?我们可以记录挂起查询或类似的内容吗?

解决方法

查看 pg_stat_activity 中“事务空闲”(如果您使用事务池模式)或“空闲”(如果您使用会话池模式)的会话。智能关闭不会停止 pgBouncer,直到最后一次此类会话自行消失。

如果终止客户端会话会导致数据完整性问题,那么您的事务管理就有问题,并且在崩溃或网络中断的情况下您将面临同样的问题。

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...