pg_checksums — 在PostgreSQL数据库集簇中启用、禁用或检查数据校验和
pg_checksums [option...] [[ -D | --pgdata ]datadir]
pg_checksums用于在PostgreSQL数据库集簇中检查、启用或禁用数据校验和。运行pg_checksums之前,必须先将服务器干净关闭。验证校验和时,如果没有校验和错误,则退出状态为零;如果检测到至少一个校验和失败,则退出状态为非零。启用或禁用校验和时,如果操作失败,则退出状态为非零。
在验证校验和时,集簇中的每个文件都会被扫描。启用校验和时,校验和发生变化的每个关系文件块都会被原地重写。 禁用校验和只会更新文件pg_control。
提供以下命令行选项:
-D directory--pgdata=directory #指定存储数据库集簇的目录。
-c--check #检查校验和。如果没有指定其他模式,这是默认模式。
-d--disable #禁用校验和。
-e--enable #启用校验和。
-f filenode--filenode=filenode #仅验证文件节点为filenode的关系中的校验和。
-N--no-sync #默认情况下,pg_checksums会等待所有文件被安全写入磁盘。该选项会使pg_checksums直接返回而不等待,这样速度更快,但也意味着如果随后操作系统崩溃,更新后的数据目录可能会损坏。通常,此选项适合测试,但不应在生产环境中使用。使用--check时,此选项不起作用。
-P--progress #启用进度报告。启用此选项后,在检查或启用校验和时会输出进度报告。
--sync-method=method #设为fsync(默认值)时,pg_checksums会递归打开并同步数据目录中的所有文件。查找文件时会跟随 WAL 目录和每个已配置表空间的符号链接。
在 Linux 上,也可以改用syncfs,请求操作系统同步包含数据目录、WAL 文件以及每个表空间的整个文件系统。使用syncfs时需注意的事项见recovery_init_sync_method。
使用--no-sync时,此选项不起作用。
-v--verbose #启用详细输出,列出所有被检查的文件。
-V--version #打印pg_checksums版本并退出。
-?--help #显示关于pg_checksums命令行参数的帮助并退出。
在大型集簇中启用校验和可能需要很长时间。在此操作期间,不得启动该集簇,也不得启动任何会向数据目录写入内容的其他程序,否则可能发生数据丢失。
在复制环境中,如果配合会直接复制关系文件块的工具(例如pg_rewind)使用,而又没有在所有节点上一致地执行启用或禁用校验和的操作,就可能因校验和不正确而导致页面损坏。因此,在复制环境中切换校验和时,建议先停止所有集簇,再一致地切换所有节点。另一种安全做法是销毁所有备库,在主库上执行该操作,最后从头重建各备库。
如果在启用或禁用校验和期间pg_checksums被中止或杀掉,那么集簇的数据校验和配置将保持不变,并且可以重新运行pg_checksums以执行同一操作。
如果您发现文档中有不正确的内容、与您使用特定功能的经验不符或需要进一步说明,请使用此表单来报告文档问题。