haenv => $haenv,
manager => undef,
status => { state => 'startup' },
+ cluster_state_update => 0,
}, $class;
$self->set_local_status({ state => 'wait_for_quorum' });
$haenv->loop_start_hook();
+ $self->{cluster_state_update} = $haenv->cluster_state_update();
+
my $res = $self->work();
$haenv->loop_end_hook();
$shutdown = 1;
} else {
+
$manager->manage();
}
};
return $self->{plug}->loop_end_hook(@args);
}
+sub cluster_state_update {
+ my ($self) = @_;
+
+ return $self->{plug}->cluster_state_update();
+}
+
sub watchdog_open {
my ($self) = @_;
sub loop_start_hook {
my ($self) = @_;
- PVE::Cluster::cfs_update();
-
$self->{loop_start} = $self->get_time();
+
}
sub loop_end_hook {
warn "loop take too long ($delay seconds)\n" if $delay > 30;
}
+sub cluster_state_update {
+ my ($self) = @_;
+
+ eval { PVE::Cluster::cfs_update(1) };
+ if (my $err = $@) {
+ $self->log('warn', "cluster file system update failed - $err");
+ return 0;
+ }
+
+ return 1;
+}
+
my $watchdog_fh;
sub watchdog_open {
shutdown_errors => 0,
# mode can be: active, reboot, shutdown, restart
mode => 'active',
+ cluster_state_update => 0,
}, $class;
$self->set_local_status({ state => 'wait_for_agent_lock' });
$haenv->loop_start_hook();
+ $self->{cluster_state_update} = $haenv->cluster_state_update();
+
my $res = $self->work();
$haenv->loop_end_hook();
# do nothing, overwrite in subclass
}
+
+sub cluster_state_update {
+ my ($self) = @_;
+
+ return $self->{hardware}->get_cfs_state($self->{nodename}, 'update');
+}
+
sub watchdog_open {
my ($self) = @_;
--- /dev/null
+Test a cfs update behavior, e.g., cfs_update fails (temporarily)
--- /dev/null
+[
+ [ "power node1 on", "power node2 on", "power node3 on"],
+ [ "cfs node1 update fail", "service vm:101 stopped" ],
+ [ "cfs node1 update work" ]
+]
--- /dev/null
+{
+ "node1": { "power": "off", "network": "off" },
+ "node2": { "power": "off", "network": "off" },
+ "node3": { "power": "off", "network": "off" }
+}
--- /dev/null
+{
+ "vm:101": { "node": "node1", "state": "enabled" },
+ "vm:102": { "node": "node2" },
+ "vm:103": { "node": "node3", "state": "enabled" }
+}