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

什么好主意吗?


当前回答

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

log_directory = 'pg_log'                    
log_filename = 'postgresql-dateformat.log'
log_statement = 'all'
logging_collector = on

其他回答

为了获得运行PostgreSQL 9.2的CentOS 6.4 (Red Hat 4.4.7-3)的更多详细信息,请参考此网页上的说明:

在/var/lib/pgsql/9.2/data/postgresql.conf中设置log_statement = 'all'和log_min_error_statement = error。 重新加载PostgreSQL配置。对我来说,这是通过运行/usr/pgsql-9.2/bin/pg_ctl reload -D /var/lib/pgsql/9.2/data/来完成的。 在/var/lib/ pg_sql /9.2/data/pg_log/中找到今天的日志

供参考:其他解决方案只记录默认数据库(通常是postgres)中的语句,以记录其他语句;从他们的解决方案开始;然后:

ALTER DATABASE your_database_name
SET log_statement = 'all';

参考:https://serverfault.com/a/376888 / log_statement

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

更改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_min_duration_statement = 0

您需要运行下面的查询,然后重新启动PostgreSQL以持久地启用日志记录。* ALTER SYSTEM SET的参数设置为postgresql.auto.conf而不是postgresql.conf:

ALTER SYSTEM SET log_statement = 'all';

并且,你需要运行下面的任意一个查询,然后重新启动PostgreSQL以永久禁用日志记录:

ALTER SYSTEM RESET log_statement;

Or:

ALTER SYSTEM SET log_statement = 'none';

你也可以运行下面的查询,然后需要重新启动PostgreSQL以启用持久日志记录:

ALTER SYSTEM SET log_min_duration_statement = 0;

并且,你也可以运行下面的查询,然后需要重新启动PostgreSQL来永久禁用日志记录:

ALTER SYSTEM RESET log_min_duration_statement;

Or:

ALTER SYSTEM SET log_min_duration_statement = -1;

注意,下面这些查询不能持久地启用或禁用日志记录:

SET SESSION log_statement = 'all'
SET log_statement = 'all'
SET LOCAL log_statement = 'all'
SET SESSION log_min_duration_statement = 0;
SET log_min_duration_statement = 0;
SET LOCAL log_min_duration_statement = 0;

Or:

RESET log_statement;
SET SESSION log_statement = 'none'
SET log_statement = 'none'
SET LOCAL log_statement = 'none'
RESET log_min_duration_statement;
SET SESSION log_min_duration_statement = -1;
SET log_min_duration_statement = -1;
SET LOCAL log_min_duration_statement = -1;