如何启用日志记录所有执行的SQL PostgreSQL 8.3?

已编辑(更多信息) 我修改了这几行:

log_directory = 'pg_log'                    
log_filename = 'postgresql-%Y-%m-%d_%H%M%S.log'
log_statement = 'all'

重启PostgreSQL服务…但是没有创建日志… 我用的是Windows Server 2003。

什么好主意吗?


当前回答

将log_statement设置为all:

错误报告和日志记录- log_statement

其他回答

将log_statement设置为all:

错误报告和日志记录- log_statement

我试图在一些postgres配置文件中设置log_statement,但实际上该文件没有被我们的postgres读取。

我确认使用请求:

select *
from pg_settings

[...]
log_statement   none # That was not the value i was expected for !!!

我用这种方式https://stackoverflow.com/a/41912295/2294168

command: postgres -c config_file=/etc/postgresql.conf
SELECT set_config('log_statement', 'all', true);

具有相应权限的用户可以使用以上查询后连接。这将影响日志记录,直到会话结束。

在data/postgresql.conf文件中,将log_statement设置更改为“all”。


Edit

看看你的新信息,我想说可能还有其他一些设置需要验证:

确保您已经打开了log_destination变量 确保您打开了logging_collector 还要确保log_directory目录已经存在于data目录中,并且postgres用户可以对其进行写操作。

你还应该设置这个参数来记录每条语句:

log_min_duration_statement = 0