]> git.proxmox.com Git - pve-cluster.git/commitdiff
fix #5461: pvecm: use ssh_info_to_command for intra cluster ssh master
authorAaron Lauterer <a.lauterer@proxmox.com>
Thu, 16 May 2024 12:08:27 +0000 (14:08 +0200)
committerFabian Grünbichler <f.gruenbichler@proxmox.com>
Wed, 22 May 2024 08:15:08 +0000 (10:15 +0200)
because otherwise the SSH calls to other nodes in the cluster will fail
on newer clusters that only have the ssh host keys located in the
pmxcfs.

With ssh_info_to_command we get all the needed SSH options that set the
alias and point to the right known_hosts file.

Signed-off-by: Aaron Lauterer <a.lauterer@proxmox.com>
src/PVE/CLI/pvecm.pm

index 0e8ca8fe8fe4cd50ac1ae14201b71894be2f6f17..cc8b3d3cfb4ac28fb05686abfa177b3c15fcfb75 100755 (executable)
@@ -18,6 +18,7 @@ use PVE::PTY;
 use PVE::API2::ClusterConfig;
 use PVE::Corosync;
 use PVE::Cluster::Setup;
+use PVE::SSHInfo;
 
 use base qw(PVE::CLIHandler);
 
@@ -173,10 +174,11 @@ __PACKAGE__->register_method ({
        run_command([@$scp_cmd, "root\@\[$qnetd_addr\]:$ca_export_file", "/etc/pve/$ca_export_base"]);
        $foreach_member->(sub {
            my ($node, $ip) = @_;
+           my $ssh_cluster_cmd = PVE::SSHInfo::ssh_info_to_command({ ip => $ip, name => $node });
            my $outsub = sub { print "\nnode '$node': " . shift };
            run_command(
-               [@$ssh_cmd, $ip, $qdevice_certutil, "-i", "-c", "/etc/pve/$ca_export_base"],
-               noerr => 1, outfunc => \&$outsub
+               [@$ssh_cluster_cmd, '--', $qdevice_certutil, "-i", "-c", "/etc/pve/$ca_export_base"],
+               noerr => 1, outfunc => $outsub
            );
        });
        unlink "/etc/pve/$ca_export_base";
@@ -206,11 +208,12 @@ __PACKAGE__->register_method ({
        run_command([@$scp_cmd, "$db_dir_node/$p12_file_base", "/etc/pve/"]);
        $foreach_member->(sub {
            my ($node, $ip) = @_;
+           my $ssh_cluster_cmd = PVE::SSHInfo::ssh_info_to_command({ ip => $ip, name => $node });
            my $outsub = sub { print "\nnode '$node': " . shift };
-           run_command([
-                   @$ssh_cmd, $ip, "$qdevice_certutil", "-m", "-c",
-                   "/etc/pve/$p12_file_base"], outfunc => \&$outsub
-               );
+           run_command(
+               [@$ssh_cluster_cmd, '--', "$qdevice_certutil", "-m", "-c", "/etc/pve/$p12_file_base"],
+               outfunc => $outsub
+           );
        });
        unlink "/etc/pve/$p12_file_base";
 
@@ -243,10 +246,17 @@ __PACKAGE__->register_method ({
 
        $foreach_member->(sub {
            my ($node, $ip) = @_;
+           my $ssh_cluster_cmd = PVE::SSHInfo::ssh_info_to_command({ ip => $ip, name => $node });
            my $outsub = sub { print "\nnode '$node': " . shift };
            print "\nINFO: start and enable corosync qdevice daemon on node '$node'...\n";
-           run_command([@$ssh_cmd, $ip, 'systemctl', 'start', 'corosync-qdevice'], outfunc => \&$outsub);
-           run_command([@$ssh_cmd, $ip, 'systemctl', 'enable', 'corosync-qdevice'], outfunc => \&$outsub);
+           run_command(
+               [@$ssh_cluster_cmd, '--', 'systemctl', 'start', 'corosync-qdevice'],
+               outfunc => $outsub
+           );
+           run_command(
+               [@$ssh_cluster_cmd, '--', 'systemctl', 'enable', 'corosync-qdevice'],
+               outfunc => $outsub
+           );
        });
 
        run_command(['corosync-cfgtool', '-R']); # do cluster wide config reload
@@ -276,8 +286,6 @@ __PACKAGE__->register_method ({
                if !$members->{$node}->{online};
        }
 
-       my $ssh_cmd = ['ssh', '-o', 'BatchMode=yes', '-lroot'];
-
        my $code = sub {
            my $conf = PVE::Cluster::cfs_read_file("corosync.conf");
            my $quorum_section = $conf->{main}->{quorum};
@@ -291,8 +299,9 @@ __PACKAGE__->register_method ({
            # cleanup qdev state (cert storage)
            my $qdev_state_dir =  "/etc/corosync/qdevice";
            $foreach_member->(sub {
-               my (undef, $ip) = @_;
-               run_command([@$ssh_cmd, $ip, '--', 'rm', '-rf', $qdev_state_dir]);
+               my ($node, $ip) = @_;
+               my $ssh_cluster_cmd = PVE::SSHInfo::ssh_info_to_command({ ip => $ip, name => $node });
+               run_command([@$ssh_cluster_cmd, '--', 'rm', '-rf', $qdev_state_dir]);
            });
        };
 
@@ -300,9 +309,10 @@ __PACKAGE__->register_method ({
        die $@ if $@;
 
        $foreach_member->(sub {
-           my (undef, $ip) = @_;
-           run_command([@$ssh_cmd, $ip, 'systemctl', 'stop', 'corosync-qdevice']);
-           run_command([@$ssh_cmd, $ip, 'systemctl', 'disable', 'corosync-qdevice']);
+           my ($node, $ip) = @_;
+           my $ssh_cluster_cmd = PVE::SSHInfo::ssh_info_to_command({ ip => $ip, name => $node });
+           run_command([@$ssh_cluster_cmd, '--', 'systemctl', 'stop', 'corosync-qdevice']);
+           run_command([@$ssh_cluster_cmd, '--', 'systemctl', 'disable', 'corosync-qdevice']);
        });
 
        run_command(['corosync-cfgtool', '-R']);