mirror of
https://github.com/postgrespro/pg_probackup.git
synced 2025-01-24 11:46:31 +02:00
disable in-place merge if backup versions are different
This commit is contained in:
parent
dfcf2d4bf9
commit
678237080f
38
src/merge.c
38
src/merge.c
@ -532,23 +532,19 @@ merge_chain(parray *parent_chain, pgBackup *full_backup, pgBackup *dest_backup)
|
|||||||
* If current program version differs from destination backup version,
|
* If current program version differs from destination backup version,
|
||||||
* then in-place merge is not possible.
|
* then in-place merge is not possible.
|
||||||
*/
|
*/
|
||||||
if (parse_program_version(dest_backup->program_version) ==
|
if ((parse_program_version(full_backup->program_version) ==
|
||||||
parse_program_version(PROGRAM_VERSION))
|
parse_program_version(dest_backup->program_version)) &&
|
||||||
|
(parse_program_version(dest_backup->program_version) ==
|
||||||
|
parse_program_version(PROGRAM_VERSION)))
|
||||||
program_version_match = true;
|
program_version_match = true;
|
||||||
else
|
else
|
||||||
elog(WARNING, "In-place merge is disabled because of program "
|
elog(WARNING, "In-place merge is disabled because of program "
|
||||||
"versions mismatch: backup %s was produced by version %s, "
|
"versions mismatch. Full backup version: %s, "
|
||||||
"but current program version is %s",
|
"destination backup version: %s, "
|
||||||
base36enc(dest_backup->start_time),
|
"current program version: %s",
|
||||||
dest_backup->program_version, PROGRAM_VERSION);
|
full_backup->program_version,
|
||||||
|
dest_backup->program_version,
|
||||||
/* Construct path to database dir: /backup_dir/instance_name/FULL/database */
|
PROGRAM_VERSION);
|
||||||
join_path_components(full_database_dir, full_backup->root_dir, DATABASE_DIR);
|
|
||||||
/* Construct path to external dir: /backup_dir/instance_name/FULL/external */
|
|
||||||
join_path_components(full_external_prefix, full_backup->root_dir, EXTERNAL_DIR);
|
|
||||||
|
|
||||||
elog(INFO, "Validate parent chain for backup %s",
|
|
||||||
base36enc(dest_backup->start_time));
|
|
||||||
|
|
||||||
/* Forbid merge retry for failed merges between 2.4.0 and any
|
/* Forbid merge retry for failed merges between 2.4.0 and any
|
||||||
* older version. Several format changes makes it impossible
|
* older version. Several format changes makes it impossible
|
||||||
@ -568,6 +564,9 @@ merge_chain(parray *parent_chain, pgBackup *full_backup, pgBackup *dest_backup)
|
|||||||
* with sole exception of FULL backup. If it has MERGING status
|
* with sole exception of FULL backup. If it has MERGING status
|
||||||
* then it isn't valid backup until merging is finished.
|
* then it isn't valid backup until merging is finished.
|
||||||
*/
|
*/
|
||||||
|
elog(INFO, "Validate parent chain for backup %s",
|
||||||
|
base36enc(dest_backup->start_time));
|
||||||
|
|
||||||
for (i = parray_num(parent_chain) - 1; i >= 0; i--)
|
for (i = parray_num(parent_chain) - 1; i >= 0; i--)
|
||||||
{
|
{
|
||||||
pgBackup *backup = (pgBackup *) parray_get(parent_chain, i);
|
pgBackup *backup = (pgBackup *) parray_get(parent_chain, i);
|
||||||
@ -611,6 +610,11 @@ merge_chain(parray *parent_chain, pgBackup *full_backup, pgBackup *dest_backup)
|
|||||||
write_backup_status(backup, BACKUP_STATUS_MERGING, instance_name, true);
|
write_backup_status(backup, BACKUP_STATUS_MERGING, instance_name, true);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* Construct path to database dir: /backup_dir/instance_name/FULL/database */
|
||||||
|
join_path_components(full_database_dir, full_backup->root_dir, DATABASE_DIR);
|
||||||
|
/* Construct path to external dir: /backup_dir/instance_name/FULL/external */
|
||||||
|
join_path_components(full_external_prefix, full_backup->root_dir, EXTERNAL_DIR);
|
||||||
|
|
||||||
/* Create directories */
|
/* Create directories */
|
||||||
create_data_directories(dest_backup->files, full_database_dir,
|
create_data_directories(dest_backup->files, full_database_dir,
|
||||||
dest_backup->root_dir, false, false, FIO_BACKUP_HOST);
|
dest_backup->root_dir, false, false, FIO_BACKUP_HOST);
|
||||||
@ -627,6 +631,7 @@ merge_chain(parray *parent_chain, pgBackup *full_backup, pgBackup *dest_backup)
|
|||||||
if (full_externals && dest_externals)
|
if (full_externals && dest_externals)
|
||||||
reorder_external_dirs(full_backup, full_externals, dest_externals);
|
reorder_external_dirs(full_backup, full_externals, dest_externals);
|
||||||
|
|
||||||
|
/* bitmap optimization rely on n_blocks, which is generally available since 2.3.0 */
|
||||||
if (parse_program_version(dest_backup->program_version) < 20300)
|
if (parse_program_version(dest_backup->program_version) < 20300)
|
||||||
use_bitmap = false;
|
use_bitmap = false;
|
||||||
|
|
||||||
@ -981,7 +986,8 @@ merge_files(void *arg)
|
|||||||
* In-place merge is also impossible, if program version of destination
|
* In-place merge is also impossible, if program version of destination
|
||||||
* backup differs from PROGRAM_VERSION
|
* backup differs from PROGRAM_VERSION
|
||||||
*/
|
*/
|
||||||
if (arguments->program_version_match && arguments->compression_match)
|
if (arguments->program_version_match && arguments->compression_match &&
|
||||||
|
!arguments->is_retry)
|
||||||
{
|
{
|
||||||
/*
|
/*
|
||||||
* Case 1:
|
* Case 1:
|
||||||
@ -1049,7 +1055,7 @@ merge_files(void *arg)
|
|||||||
* page header map cannot be trusted when retrying, so no
|
* page header map cannot be trusted when retrying, so no
|
||||||
* in place merge for retry.
|
* in place merge for retry.
|
||||||
*/
|
*/
|
||||||
if (in_place && !arguments->is_retry)
|
if (in_place)
|
||||||
{
|
{
|
||||||
pgFile **res_file = NULL;
|
pgFile **res_file = NULL;
|
||||||
pgFile *file = NULL;
|
pgFile *file = NULL;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user