auto_explain

一个自动记录慢速语句执行计划的contrib模块

auto_explain 是一个contrib模块,它使PostgreSQL能够自动记录慢速查询的执行计划。

auto_explain 添加于 PostgreSQL 8.4

更改历史

配置

通常,auto_explain 包含在 postgresql.confshared_preload_libraries 选项中,以跟踪所有数据库会话中的慢速查询。超级用户也可以使用 LOAD 'auto_explain' 将其加载到单个会话中。请注意,无法为单个数据库启用 auto_explain

使用 auto_explain 会带来一些额外的开销,并可能影响数据库的整体性能。因此,只有在需要时才应启用它。

默认情况下,auto_explain 未激活,直到显式配置。至少,必须设置 auto_explain.log_min_duration 为零(“记录所有计划”)或更大(要记录的语句的最小持续时间,以毫秒为单位)。有关所有配置选项的详细信息,请参见 auto_explain 文档。只有超级用户才能设置配置选项。

示例

在一个会话中启用 auto_explain

postgres=# LOAD 'auto_explain';
LOAD
postgres=# SET auto_explain.log_min_duration = 0;
SET
postgres=# SELECT count(*)
             FROM pgbench_branches b
             JOIN pgbench_accounts a ON b.bid = a.bid;
 count  
--------
 100000
(1 row)

服务器日志将包含类似于以下内容的输出

LOG:  duration: 26.516 ms  plan:
        Query Text: SELECT count(*)
                      FROM pgbench_branches b
                      JOIN pgbench_accounts a ON b.bid = a.bid;
        Aggregate  (cost=4141.01..4141.02 rows=1 width=0)
          ->  Nested Loop  (cost=0.00..3891.01 rows=100000 width=0)
                Join Filter: (b.bid = a.bid)
                ->  Seq Scan on pgbench_branches b  (cost=0.00..1.01 rows=1 width=4)
                ->  Seq Scan on pgbench_accounts a  (cost=0.00..2640.00 rows=100000 width=4)

分类

Contrib模块性能

反馈

提交任何关于 "auto_explain" 的评论、建议或更正 在此