如何启用日志记录所有执行的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。
什么好主意吗?
如何启用日志记录所有执行的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
其他回答
为了获得运行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/中找到今天的日志
您需要运行下面的查询,然后重新启动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;
我试图在一些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
编辑/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
SELECT set_config('log_statement', 'all', true);
具有相应权限的用户可以使用以上查询后连接。这将影响日志记录,直到会话结束。