类型: | bool |
默认: | off |
上下文: | sighup |
重新开始: | false |
当logging_collector被启用时,这个参数将导致PostgreSQL截断(覆盖而不是追加)任何已有的同名日志文件。不过,截断只在一个新文件由于基于时间的轮转被打开时发生,在服务器启动或基于尺寸的轮转时不会发生。如果被关闭,在所有情况下以前存在的文件将被追加。例如,使用这个设置和一个类似postgresql-%H.log
的log_filename将导致产生 24 个每小时的日志文件,并且循环地覆盖它们。这个参数只能在postgresql.conf文件中或在服务器命令行上设置。
例子:要保留 7 天的日志,每天的一个日志文件被命令为server_log.Mon
、server_log.Tue
等等,并且自动用本周的日志覆盖上一周的日志。可以这样做:将log_filename设置为server_log.%a
、将log_truncate_on_rotation
设置为on
并且将log_rotation_age设置为1440
。
例子:要保留 24 小时的日志,每个小时一个日志文件,但是在日志文件尺寸超过 1GB 时轮转。可以这样做:将log_filename设置为server_log.%H%M
、 将log_truncate_on_rotation
设置为on
、 将log_rotation_age设置为60
并且 将log_rotation_size设置为1000000
。 在log_filename中包括%M
允许发生任何尺寸驱动的轮转来选择一个不同于每个小时的初始文件名的新文件名。
建议 [EN]
Set to “on” for production with a reusable logfile name to limit log accumulation if you don't have a sysadmin script to do so.