replication: use a dedicated lock file
Otherwise $update_job_state's file_set_contents() call drops our lock.
This commit is contained in:
parent
2cbdbd8105
commit
c5e08dfe7e
@ -22,6 +22,7 @@ use PVE::ReplicationConfig;
|
||||
|
||||
# Note: regression tests can overwrite $state_path for testing
|
||||
our $state_path = "/var/lib/pve-manager/pve-replication-state.json";
|
||||
our $pvesr_lock_path = "/var/lock/pvesr.lck";
|
||||
|
||||
my $update_job_state = sub {
|
||||
my ($stateobj, $jobcfg, $state) = @_;
|
||||
@ -506,7 +507,7 @@ sub run_single_job {
|
||||
$run_replication->($stateobj, $jobcfg, $now, $logfunc);
|
||||
};
|
||||
|
||||
my $res = PVE::Tools::lock_file($state_path, 60, $code);
|
||||
my $res = PVE::Tools::lock_file($pvesr_lock_path, 60, $code);
|
||||
die $@ if $@;
|
||||
}
|
||||
|
||||
@ -525,7 +526,7 @@ sub run_jobs {
|
||||
}
|
||||
};
|
||||
|
||||
my $res = PVE::Tools::lock_file($state_path, 60, $code);
|
||||
my $res = PVE::Tools::lock_file($pvesr_lock_path, 60, $code);
|
||||
die $@ if $@;
|
||||
}
|
||||
|
||||
|
@ -18,4 +18,4 @@ install:
|
||||
|
||||
.PHONY: clean
|
||||
clean:
|
||||
rm -rf *~
|
||||
rm -rf *~ .mocked_* *.tmp
|
||||
|
@ -60,6 +60,7 @@ my $statefile = ".mocked_repl_state";
|
||||
|
||||
unlink $statefile;
|
||||
$PVE::Replication::state_path = $statefile;
|
||||
$PVE::Replication::pvesr_lock_path = ".mocked_pvesr_lock";
|
||||
|
||||
my $mocked_write_state = sub {
|
||||
my ($state) = @_;
|
||||
|
Loading…
x
Reference in New Issue
Block a user