Error out in pg_verify_checksums on incompatible block size
authorMichael Paquier <michael@paquier.xyz>
Mon, 18 Mar 2019 00:12:24 +0000 (09:12 +0900)
committerMichael Paquier <michael@paquier.xyz>
Mon, 18 Mar 2019 00:12:24 +0000 (09:12 +0900)
pg_verify_checksums is compiled with a given block size and has a hard
dependency to it per the way checksums are calculated via
checksum_impl.h, and trying to use the tool on a data folder which has
not the same block size would result in incorrect checksum calculations
and/or block read errors, meaning that the data folder is corrupted.
This is harmless as checksums are only checked now, but very confusing
for the user so issue an error properly if the block size used at
compilation and the block size used in the data folder do not match.

Reported-by: Sergei Kornilov
Author: Michael Banck, Michael Paquier
Reviewed-by: Fabien Coelho, Magnus Hagander
Discussion: https://postgr.es/m/20190317054657.GA3357@paquier.xyz
ackpatch-through: 11

src/bin/pg_verify_checksums/pg_verify_checksums.c

index a992886a32327404487b90a0a6aba32c163da1da..3ab0170977b2607f373c5a3f9b591f2d4bfab07d 100644 (file)
@@ -323,6 +323,15 @@ main(int argc, char *argv[])
        exit(1);
    }
 
+   if (ControlFile->blcksz != BLCKSZ)
+   {
+       fprintf(stderr, _("%s: database cluster is not compatible.\n"),
+               progname);
+       fprintf(stderr, _("The database cluster was initialized with block size %u, but pg_checksums was compiled with block size %u.\n"),
+               ControlFile->blcksz, BLCKSZ);
+       exit(1);
+   }
+
    if (ControlFile->state != DB_SHUTDOWNED &&
        ControlFile->state != DB_SHUTDOWNED_IN_RECOVERY)
    {