PostgreSQL教程(8)归档日志配置

PostgreSQL教程(8)归档日志配置

一、PostgreSQL 归档模式

在默认情况下,PostgreSQL采用的是非归档模式,在该模式下WAL日志被写满后会触发轮询,将前面的日志覆盖掉,导致WAL日志丢失。如果数据库实例变更频繁,那么WAL日志很可能在不断轮询,这样容易出现想恢复到某一刻数据的时候因为WAL日志被覆盖了而无法恢复的情况。所以在生产环境中都强烈建议开启归档模式,在归档模式下,PostgreSQL 会先将早期产生的WAL日志按照要求进行备份后再进行覆盖,避免WAL日志丢失。

二、PostgreSQL 日志归档配置

1、查看当前归档模式

#默认为off
postgres=# show archive_mode;
 archive_mode 
--------------
 off
(1 row)

2、开启归档模式

修改 postgres.conf 配置文件,开启归档功能并配置归档命令

vi postgres.conf
# 启用归档模式
archive_moed = on 
   
# 归档命令配置
# %p表示WAL日志的绝对路径,如/data/pgsql/pg_wal/000000010000000000000065
# %f表示WAL日志的文件名,不含路径,如000000010000000000000065
archive_command = 'test ! -f /data/pgarchive/%f && cp %p /data/pg_archive/%f'

3、查看当前WAL日志列表

postgres=# select * from pg_ls_waldir();
           name           |   size   |      modification      
--------------------------+----------+------------------------
 0000000100000000000000B9 | 16777216 | 2025-09-08 22:30:41+08
 0000000100000000000000BA | 16777216 | 2025-09-08 22:30:41+08
 0000000100000000000000BB | 16777216 | 2025-09-08 22:30:41+08
 0000000100000000000000BC | 16777216 | 2025-09-08 22:30:41+08
 0000000100000000000000BD | 16777216 | 2025-09-08 22:30:41+08
 0000000100000000000000BE | 16777216 | 2025-09-08 22:30:42+08
 0000000100000000000000BF | 16777216 | 2025-09-08 22:30:42+08
 0000000100000000000000C0 | 16777216 | 2025-09-08 22:30:42+08

4、查看归档日志占用磁盘情况

select count(*), pg_size_pretty(sum(size)) 
postgres-# from pg_ls_waldir();
 count | pg_size_pretty 
-------+----------------
    64 | 1024 MB

5、手动切换WAL日志触发归档

在 PostgreSQL中,当 WAL 文件被写满或发生WAL切换时,数据库就会去执行 archive_command,把这个完整的 WAL 文件复制到归档目录,所以这里为了模拟效果进行手动的WAL日志切换,生成一个新的 WAL 文件

select pg_switch_wal();

6、查看是否正常归档

ls /data/pg_archive

三、归档日志的清理

由于PostgreSQL内部机制原因,它并不会自动对归档日志进行处理,而是持续存放在归档目录中。如果没有配置一个合理的清理策略,会导致磁盘空间被占满。为了避免上述问题,需要根据备份周期来进行归档日志的清理策略,通常保留两次全量备份之间的所有归档数据,这样可以起到一个增量备份的作用,可以灵活的进行时间点恢复。

在生产环境中,推荐使用 pgBackRest、barman 等工具,它们能在执行全量/增量备份后自动管理归档日志的保留和清理。如果不使用工具,则需要 DBA 定期编写脚本手工清理,确保既能满足恢复需求,又避免磁盘被日志撑满。另外 PostgreSQL 还提供了一个内置工具 pg_archivecleanup 用于清理不再需要的归档日志。

#pg_archivecleanup <归档目录路径> <保留的起始WAL文件>
pg_archivecleanup /data/pgarchive 0000000100000000000000A5


文章评论

猜你喜欢

【MySQL 8.0】MySQL 8.0新特性介绍与升级方法

MySQL | Oracle 【MySQL 8.0】MySQL 8.0新特性介绍与升级方法

一、MySQL 8.0主要新特性截至2023年12月,MySQL官方发布的稳定版为8.0.35,另有一个MySQL8.2为创新版,所以暂不做考虑· 快速新增/删除列虽然 MySQL 在8.0 以前就已...

【MySQL 8.0】MySQL5.7升级MySQL8.0的步骤与常见问题

MySQL | Oracle 【MySQL 8.0】MySQL5.7升级MySQL8.0的步骤与常见问题

一、为什么推荐将MySQL从5.7升级到8.0MySQL5.7的生命周期已经在2023年10月结束,沿用老版本将存在以下问题:· 所有漏洞不再修复,如自增ID回退问题· 核心新特性无法使用,...

MySQL | Oracle Oracle教程(4)快照与AWR报告

Oracle教程(4)快照与AWR报告
Oracle教程(4)快照与AWR报告
Oracle教程(4)快照与AWR报告
Oracle教程(4)快照与AWR报告

一、Oracle 快照Oracle中的快照(Snapshot)是指数据库在某个时间点对性能相关的数据做的一次全量采集。包括:系统资源使用情况、Top SQL、IO 性能指标、SGA、PGA 使用情况。...

Oracle教程(3)Schema、用户与表空间

MySQL | Oracle Oracle教程(3)Schema、用户与表空间

在完成 Oracle安装后,登录数据库实例可以看到有很多的模式(Schema),这些模式都是为了支持数据库核心组件、特性扩展、管理任务或者示例而创建,对于这部分默认模式,通常不需要进行操作。在生产规范...

Oracle教程(2)Oracle19C命令行静默安装教程

MySQL | Oracle Oracle教程(2)Oracle19C命令行静默安装教程

在部分生产环境下可能并不支持通过图形化方式来安装Oracle数据库(比如需要脚本一键安装的场景),所以还需要了解通过命令行静默安装的方式来完整数据库的安装,以下是详细步骤一、系统环境配置部分1、确定内...