测量 PostgreSQL 中失败查询的 XID 使用情况



我正在调查Postgres数据库上经常执行的查询,以帮助减少XID的使用。我可以使用 pg_stat_statements 获取执行的查询列表和调用次数,但它不包括由于唯一约束冲突等原因而失败的查询。有没有办法记录和获取这些失败查询的计数?

例:

test_xid=# d test
     Table "public.test"
 Column |  Type   | Modifiers 
--------+---------+-----------
 id     | integer | not null
Indexes:
    "test_pkey" PRIMARY KEY, btree (id)
test_xid=# truncate test;
TRUNCATE TABLE
test_xid=# select pg_stat_statements_reset();
 pg_stat_statements_reset 
--------------------------
(1 row)
test_xid=# select txid_current();
 txid_current 
--------------
       224547
(1 row)
test_xid=# insert into test(id) values (1);
INSERT 0 1
test_xid=# insert into test(id) values (1);
ERROR:  duplicate key value violates unique constraint "test_pkey"
DETAIL:  Key (id)=(1) already exists.
test_xid=# insert into test(id) values (1);
ERROR:  duplicate key value violates unique constraint "test_pkey"
DETAIL:  Key (id)=(1) already exists.
test_xid=# insert into test(id) values (1);
ERROR:  duplicate key value violates unique constraint "test_pkey"
DETAIL:  Key (id)=(1) already exists.
test_xid=# select txid_current();
 txid_current 
--------------
       224552
(1 row)
test_xid=# select query, calls from pg_stat_statements;
               query                | calls 
------------------------------------+-------
 insert into test(id) values (?);   |     1
 select pg_stat_statements_reset(); |     1
 select txid_current();             |     2
(3 rows)
test_xid=# select pg_stat_statements_reset();
 pg_stat_statements_reset 
--------------------------
(1 row)
test_xid=# insert into test(id) values (1);
ERROR:  duplicate key value violates unique constraint "test_pkey"
DETAIL:  Key (id)=(1) already exists.
test_xid=# select query, calls from pg_stat_statements;
               query                | calls 
------------------------------------+-------
 select pg_stat_statements_reset(); |     1
(1 row)

可以看出,如果 INSERT 查询始终失败,则不会显示在pg_stat_statments中,并且如果成功执行时已存在查询,则调用计数不会因后续失败的查询而增加,即使失败的查询导致当前 XID 增加。

有关一般统计信息,您可以查看pg_stat_database.xact_rollback。如果你想知道回滚的语句,我能想到的唯一不涉及 C 代码的事情就是记录所有语句,然后查看日志。

如果你想深入研究 C 代码(或付钱给某人),我认为向pg_stat_statements添加回滚支持并不是非常困难,我怀疑社区会欢迎这一点。

最新更新