如何启用日志记录所有执行的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。

什么好主意吗?


当前回答

我试图在一些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

其他回答

你还需要在PostgreSQL中添加这些行,并重新启动服务器:

log_directory = 'pg_log'                    
log_filename = 'postgresql-dateformat.log'
log_statement = 'all'
logging_collector = on
SELECT set_config('log_statement', 'all', true);

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

动态地,我们可以用两种方式启用/禁用日志记录

更改DB中的全局变量并重新加载配置 a)设置log_statement = 'all';或者设置log_min_duration_statement = 0; B) select pg_reload_conf(); 从Linux命令行,编辑postgres配置文件,修改日志相关参数 Log_min_duration_statement = 0 Log_statement = 'all' 重新加载配置文件 Su - postgres /usr/bin/pg_ctl重载

在这两种情况下,我们都不应该重新启动Postgres。我们可以通过配置重新加载动态启用/禁用日志记录。

我希望这对你有所帮助。

将log_statement设置为all:

错误报告和日志记录- log_statement

编辑/etc/postgresql/9.3/main/postgresql.conf文件,修改如下。

注意:如果你没有找到postgresql.conf文件,那么在终端中输入$locate postgresql.conf即可

#log_directory = 'pg_log'到log_directory = 'pg_log' # log_filename = ' postgresql - Y % % m - H % d_ % % m % S.log”log_filename =“postgresql - Y % % m - H % d_ % % m % S.log” #log_statement = 'none'到log_statement = 'all' #logging_collector = off到logging_collector = on 可选:SELECT set_config('log_statement', 'all', true); sudo /etc/init.D /postgresql restart或sudo service postgresql restart 火灾查询在postgresql选择2+2 在/var/lib/ pg_sql /9.2/data/pg_log/中查找当前日志

日志文件在一段时间内会增长很多,可能会杀死您的机器。为了安全起见,编写一个bash脚本,删除日志并重新启动postgresql服务器。

谢谢@paul, @Jarret Hardie, @Zoltán, @Rix Beck, @Latif Premani