This fixes a bug introduced by commit 9da84a0 which set the wrong hash when a disabled service got a migrate/relocate command.
We set "node => $target", while our state machine could handle that we got some "uninitialized value" warnings when migrating a disabled service to an inactive LRM. Better set "target => $target" Further add a test for this scenario. Signed-off-by: Thomas Lamprecht <t.lampre...@proxmox.com> --- src/PVE/HA/Manager.pm | 3 +- src/test/test-relocate-to-inactive-node/README | 1 + src/test/test-relocate-to-inactive-node/cmdlist | 4 +++ .../test-relocate-to-inactive-node/hardware_status | 5 ++++ src/test/test-relocate-to-inactive-node/log.expect | 33 ++++++++++++++++++++++ .../test-relocate-to-inactive-node/manager_status | 1 + .../test-relocate-to-inactive-node/service_config | 3 ++ 7 files changed, 49 insertions(+), 1 deletion(-) create mode 100644 src/test/test-relocate-to-inactive-node/README create mode 100644 src/test/test-relocate-to-inactive-node/cmdlist create mode 100644 src/test/test-relocate-to-inactive-node/hardware_status create mode 100644 src/test/test-relocate-to-inactive-node/log.expect create mode 100644 src/test/test-relocate-to-inactive-node/manager_status create mode 100644 src/test/test-relocate-to-inactive-node/service_config diff --git a/src/PVE/HA/Manager.pm b/src/PVE/HA/Manager.pm index a482ef2..c03690f 100644 --- a/src/PVE/HA/Manager.pm +++ b/src/PVE/HA/Manager.pm @@ -509,7 +509,8 @@ sub next_state_stopped { } elsif ($sd->{node} eq $target) { $haenv->log('info', "ignore service '$sid' $cmd request - service already on node '$target'"); } else { - &$change_service_state($self, $sid, $cmd, node => $target); + &$change_service_state($self, $sid, $cmd, node => $sd->{node}, + target => $target); return; } } else { diff --git a/src/test/test-relocate-to-inactive-node/README b/src/test/test-relocate-to-inactive-node/README new file mode 100644 index 0000000..f8bffe3 --- /dev/null +++ b/src/test/test-relocate-to-inactive-node/README @@ -0,0 +1 @@ +Test user triggered service migration. diff --git a/src/test/test-relocate-to-inactive-node/cmdlist b/src/test/test-relocate-to-inactive-node/cmdlist new file mode 100644 index 0000000..4238140 --- /dev/null +++ b/src/test/test-relocate-to-inactive-node/cmdlist @@ -0,0 +1,4 @@ +[ + [ "power node1 on", "power node2 on", "power node3 on"], + [ "service vm:103 relocate node2" ] +] diff --git a/src/test/test-relocate-to-inactive-node/hardware_status b/src/test/test-relocate-to-inactive-node/hardware_status new file mode 100644 index 0000000..451beb1 --- /dev/null +++ b/src/test/test-relocate-to-inactive-node/hardware_status @@ -0,0 +1,5 @@ +{ + "node1": { "power": "off", "network": "off" }, + "node2": { "power": "off", "network": "off" }, + "node3": { "power": "off", "network": "off" } +} diff --git a/src/test/test-relocate-to-inactive-node/log.expect b/src/test/test-relocate-to-inactive-node/log.expect new file mode 100644 index 0000000..c4e6d02 --- /dev/null +++ b/src/test/test-relocate-to-inactive-node/log.expect @@ -0,0 +1,33 @@ +info 0 hardware: starting simulation +info 20 cmdlist: execute power node1 on +info 20 node1/crm: status change startup => wait_for_quorum +info 20 node1/lrm: status change startup => wait_for_agent_lock +info 20 cmdlist: execute power node2 on +info 20 node2/crm: status change startup => wait_for_quorum +info 20 node2/lrm: status change startup => wait_for_agent_lock +info 20 cmdlist: execute power node3 on +info 20 node3/crm: status change startup => wait_for_quorum +info 20 node3/lrm: status change startup => wait_for_agent_lock +info 20 node1/crm: got lock 'ha_manager_lock' +info 20 node1/crm: status change wait_for_quorum => master +info 20 node1/crm: node 'node1': state changed from 'unknown' => 'online' +info 20 node1/crm: node 'node2': state changed from 'unknown' => 'online' +info 20 node1/crm: node 'node3': state changed from 'unknown' => 'online' +info 20 node1/crm: adding new service 'vm:103' on node 'node3' +info 20 node1/crm: service 'vm:103': state changed from 'started' to 'request_stop' +info 22 node2/crm: status change wait_for_quorum => slave +info 24 node3/crm: status change wait_for_quorum => slave +info 25 node3/lrm: got lock 'ha_agent_node3_lock' +info 25 node3/lrm: status change wait_for_agent_lock => active +info 40 node1/crm: service 'vm:103': state changed from 'request_stop' to 'stopped' +info 120 cmdlist: execute service vm:103 relocate node2 +info 120 node1/crm: got crm command: relocate vm:103 node2 +info 120 node1/crm: service 'vm:103': state changed from 'stopped' to 'relocate' (node = node3, target = node2) +info 125 node3/lrm: service vm:103 - start relocate to node 'node2' +info 125 node3/lrm: service vm:103 - end relocate to node 'node2' +info 140 node1/crm: service 'vm:103': state changed from 'relocate' to 'started' (node = node2) +info 140 node1/crm: service 'vm:103': state changed from 'started' to 'request_stop' +info 143 node2/lrm: got lock 'ha_agent_node2_lock' +info 143 node2/lrm: status change wait_for_agent_lock => active +info 160 node1/crm: service 'vm:103': state changed from 'request_stop' to 'stopped' +info 720 hardware: exit simulation - done diff --git a/src/test/test-relocate-to-inactive-node/manager_status b/src/test/test-relocate-to-inactive-node/manager_status new file mode 100644 index 0000000..0967ef4 --- /dev/null +++ b/src/test/test-relocate-to-inactive-node/manager_status @@ -0,0 +1 @@ +{} diff --git a/src/test/test-relocate-to-inactive-node/service_config b/src/test/test-relocate-to-inactive-node/service_config new file mode 100644 index 0000000..fe1359f --- /dev/null +++ b/src/test/test-relocate-to-inactive-node/service_config @@ -0,0 +1,3 @@ +{ + "vm:103": { "node": "node3", "state": "disabled" } +} -- 2.1.4 _______________________________________________ pve-devel mailing list pve-devel@pve.proxmox.com http://pve.proxmox.com/cgi-bin/mailman/listinfo/pve-devel