PostgreSQL自带的命令行工具01- pg_archivecleanup
- 基础信息
- OS版本:Red Hat Enterprise Linux Server release 7.9 (Maipo)
- DB版本:16.2
- pg软件目录:/home/pg16/soft
- pg数据目录:/home/pg16/data
- 端口:5777
复制代码 pg_archivecleanup 是 PostgreSQL 中用于管理 WAL(Write-Ahead Logging)归档目录的工具。在使用基于归档的日记复制或持久化存储时,pg_archivecleanup 用来清算那些不再必要的归档日记文件,帮助节省存储空间,并维持归档目录的整洁。
WAL 是 PostgreSQL 事件日记的一部分,用于保证数据库的事件完整性和持久性。在配置了WAL归档的PostgreSQL数据库中,每个事件会先写入 WAL 文件,然后定期这些 WAL 文件会被归档到指定的目录。随着时间的推移,这些归档的 WAL 文件可以累积到非常大的体积,特别是在高负载的系统中。因此,符合地清算这些不再必要的 WAL 归档文件对于管理存储非常关键。
使用方式
pg_archivecleanup 通常在备份策略或复制配置中自动调用,尤其是与归档清算相关的操纵中。它的基本用法如下:
- pg_archivecleanup <archive_location> <oldest_required_wal_file>
复制代码
- <archive_location> 是 WAL 文件被归档到的目录路径。
- <oldest_required_wal_file> 指定了在归档目录中必要保留的最旧的文件。pg_archivecleanup 会删除全部比这个文件更旧的 WAL 文件。
例如,pg_archivecleanup /var/lib/postgresql/wal_archives 00000001000000000000007B 命令会删除 /var/lib/postgresql/wal_archives 目录下全部早于文件 00000001000000000000007B 的归档 WAL 文件。
–通过help查察更多信息
- [pg16@test bin]$ pg_archivecleanup --help
- pg_archivecleanup removes older WAL files from PostgreSQL archives.
- Usage:
- pg_archivecleanup [OPTION]... ARCHIVELOCATION OLDESTKEPTWALFILE
- Options:
- -d generate debug output (verbose mode)
- -n dry run, show the names of the files that would be removed
- -V, --version output version information, then exit
- -x EXT clean up files if they have this extension
- -?, --help show this help, then exit
- For use as archive_cleanup_command in postgresql.conf:
- archive_cleanup_command = 'pg_archivecleanup [OPTION]... ARCHIVELOCATION %r'
- e.g.
- archive_cleanup_command = 'pg_archivecleanup /mnt/server/archiverdir %r'
- Or for use as a standalone archive cleaner:
- e.g.
- pg_archivecleanup /mnt/server/archiverdir 000000010000000000000010.00000020.backup
- Report bugs to <pgsql-bugs@lists.postgresql.org>.
- PostgreSQL home page: <https://www.postgresql.org/>
复制代码 测试:删除 000000010000000000000005 之前的归档日记
- [pg16@test archivelog]$ ll
- total 458752
- -rw------- 1 pg16 pg16 16777216 Apr 17 07:16 000000010000000000000002
- -rw------- 1 pg16 pg16 16777216 Apr 17 07:16 000000010000000000000003
- -rw------- 1 pg16 pg16 16777216 Apr 17 07:16 000000010000000000000004
- -rw------- 1 pg16 pg16 16777216 Apr 17 07:16 000000010000000000000005
- -rw------- 1 pg16 pg16 16777216 Apr 17 07:16 000000010000000000000006
- -rw------- 1 pg16 pg16 16777216 Apr 17 07:16 000000010000000000000007
- -rw------- 1 pg16 pg16 16777216 Apr 17 07:16 000000010000000000000008
- -rw------- 1 pg16 pg16 16777216 Apr 17 07:16 000000010000000000000009
- -rw------- 1 pg16 pg16 16777216 Apr 17 07:16 00000001000000000000000A
- -rw------- 1 pg16 pg16 16777216 Apr 17 08:11 00000001000000000000000B
- -rw------- 1 pg16 pg16 16777216 Apr 17 08:19 00000001000000000000000C
- -rw------- 1 pg16 pg16 16777216 Apr 17 08:19 00000001000000000000000D
- -rw------- 1 pg16 pg16 16777216 Apr 17 08:19 00000001000000000000000E
- -rw------- 1 pg16 pg16 16777216 Apr 17 08:19 00000001000000000000000F
- -rw------- 1 pg16 pg16 16777216 Apr 17 08:19 000000010000000000000010
- -rw------- 1 pg16 pg16 16777216 Apr 17 08:19 000000010000000000000011
- -rw------- 1 pg16 pg16 16777216 Apr 17 08:22 000000010000000000000012
- -rw------- 1 pg16 pg16 16777216 Apr 17 08:27 000000010000000000000013
- -rw------- 1 pg16 pg16 16777216 Apr 22 07:20 000000010000000000000014
- -rw------- 1 pg16 pg16 16777216 Apr 22 07:56 000000010000000000000015
- -rw------- 1 pg16 pg16 16777216 Apr 24 21:17 000000010000000000000016
- -rw------- 1 pg16 pg16 16777216 Apr 24 21:22 000000010000000000000017
- -rw------- 1 pg16 pg16 16777216 Apr 24 21:37 000000010000000000000018
- -rw------- 1 pg16 pg16 16777216 Apr 24 21:38 000000010000000000000019
- -rw------- 1 pg16 pg16 16777216 Apr 24 21:39 00000001000000000000001A
- -rw------- 1 pg16 pg16 16777216 Apr 24 21:44 00000001000000000000001B
- -rw------- 1 pg16 pg16 16777216 Apr 25 03:52 00000001000000000000001C
- -rw------- 1 pg16 pg16 16777216 Apr 26 03:45 00000001000000000000001D
- [pg16@test archivelog]$ which pg_archivecleanup
- ~/soft/bin/pg_archivecleanup
- [pg16@test archivelog]$ pg_archivecleanup ~/archivelog/ 000000010000000000000005
- [pg16@test archivelog]$ ll
- total 409600
- -rw------- 1 pg16 pg16 16777216 Apr 17 07:16 000000010000000000000005
- -rw------- 1 pg16 pg16 16777216 Apr 17 07:16 000000010000000000000006
- -rw------- 1 pg16 pg16 16777216 Apr 17 07:16 000000010000000000000007
- -rw------- 1 pg16 pg16 16777216 Apr 17 07:16 000000010000000000000008
- -rw------- 1 pg16 pg16 16777216 Apr 17 07:16 000000010000000000000009
- -rw------- 1 pg16 pg16 16777216 Apr 17 07:16 00000001000000000000000A
- -rw------- 1 pg16 pg16 16777216 Apr 17 08:11 00000001000000000000000B
- -rw------- 1 pg16 pg16 16777216 Apr 17 08:19 00000001000000000000000C
- -rw------- 1 pg16 pg16 16777216 Apr 17 08:19 00000001000000000000000D
- -rw------- 1 pg16 pg16 16777216 Apr 17 08:19 00000001000000000000000E
- -rw------- 1 pg16 pg16 16777216 Apr 17 08:19 00000001000000000000000F
- -rw------- 1 pg16 pg16 16777216 Apr 17 08:19 000000010000000000000010
- -rw------- 1 pg16 pg16 16777216 Apr 17 08:19 000000010000000000000011
- -rw------- 1 pg16 pg16 16777216 Apr 17 08:22 000000010000000000000012
- -rw------- 1 pg16 pg16 16777216 Apr 17 08:27 000000010000000000000013
- -rw------- 1 pg16 pg16 16777216 Apr 22 07:20 000000010000000000000014
- -rw------- 1 pg16 pg16 16777216 Apr 22 07:56 000000010000000000000015
- -rw------- 1 pg16 pg16 16777216 Apr 24 21:17 000000010000000000000016
- -rw------- 1 pg16 pg16 16777216 Apr 24 21:22 000000010000000000000017
- -rw------- 1 pg16 pg16 16777216 Apr 24 21:37 000000010000000000000018
- -rw------- 1 pg16 pg16 16777216 Apr 24 21:38 000000010000000000000019
- -rw------- 1 pg16 pg16 16777216 Apr 24 21:39 00000001000000000000001A
- -rw------- 1 pg16 pg16 16777216 Apr 24 21:44 00000001000000000000001B
- -rw------- 1 pg16 pg16 16777216 Apr 25 03:52 00000001000000000000001C
- -rw------- 1 pg16 pg16 16777216 Apr 26 03:45 00000001000000000000001D
- [pg16@test archivelog]$
复制代码 配置场景
pg_archivecleanup 的一个常见应用场景是在流复制的备用服务器上用作 restore_command 的一部分,以自动清算那些不再必要应用到备用服务器上的 WAL 归档文件。例如,在 recovery.conf 或针对 PostgreSQL 12 及以后版本的 postgresql.conf 文件中,可以如许配置:
- restore_command = 'cp /mnt/server/archivedir/%f %p && pg_archivecleanup /mnt/server/archivedir %r'
复制代码 这条命令在实行规复每个WAL文件后,使用 pg_archivecleanup 清算不再必要的文件,%f 代表要规复的文件名,%p 代表要规复到的路径,%r 代表此次规复操纵中必要的最旧的WAL文件。如许配置后,可以自动地维护归档目录的巨细。
注意事项
- 使用 pg_archivecleanup 时必要谨慎,以免不小心删除了仍然必要的 WAL 文件。
- 确认 WAL 归档策略和备份规复策略,并与之相共同使用 pg_archivecleanup。
- 在实行任何清算操纵之前,确保已经有了对应的WAL文件的备份,以防万一。
pg_archivecleanup 是 PostgreSQL 提供的一个非常实用的工具,对于管理 WAL 归档和维持长期运行的 PostgreSQL 系统的康健非常有助益。
谨记:心存敬畏,行有所止。
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。 |