在C#中的ssh.net下命令未完全执行

时间:2018-09-06 23:39:26

标签: c# xen libvirt ssh.net

我正在使用由constructVirtBuilderCommand生成的字符串,并将其用作服务器在xen中生成图像所需的命令。但是,该命令返回了多个信息,因为它通知您libvirt在下载映像的过程中执行了多个步骤,返回的第一(也是唯一)信息是“ [2.5]下载:http://libguestfs.org/download/builder/ubuntu-18.04.xz”,但是只是整个输出的一行:

[3.2]下载:http://libguestfs.org/download/builder/ubuntu-18.04.xz

[4.7]规划如何构建此图像

[4.7]解压缩

[14.7]调整大小(使用virt-resize)以将磁盘扩展到15.0G

[497.3]安装firstboot命令:重新启动

[497.7]设置密码

[510.8]完成

         Output file: test.img
         Output size: 15.0G
         Output format: raw
         Total usable space: 14.7G
         Free space: 13.2G (99%)

这似乎对我造成了问题。因为命令在返回之前没有完全执行。有没有人有这个问题的经验?没有为我下载任何图像-如果只有该图像仅存在片刻,并且在开始下载另一张图像后文件突然消失。我已经尝试了一些方法来强制客户端等待其完成下载图像。第一个是在命令末尾附加“ | grep Finishing”。我尝试的第二件事是“> file.txt”在命令完全执行后生成此文件,但效果不佳。

有人可以帮助我弄清楚如何使libvirt完全执行此命令吗?如果我在服务器上通过ssh手动将其输入,则它可以正常工作。谢谢!

    private String constructVirtBuilderCommand()
    {
        String virt_builder_command = "sudo virt-builder ";
        virt_builder_command += operating_system_comboBox.SelectedItem.ToString();
        virt_builder_command += "-";
        virt_builder_command += operating_system_version_comboBox.SelectedItem.ToString();
        virt_builder_command += " --arch ";
        virt_builder_command += operating_system_architecture_comboBox.SelectedItem.ToString();
        virt_builder_command += " -o nodeand#.img --size ";
        virt_builder_command += storage_textBox.Text;
        virt_builder_command += "G --root-password password:toor --firstboot-command 'reboot'";
        return virt_builder_command;
    }



    private void add_new_cluster_button_Click(object sender, EventArgs e)
    {

        if (new_cluster_name_textBox.Text != "")
        {

            String virtbuilder = constructVirtBuilderCommand();
            String virtinstaller = constructVirtInstallCommand();
            for (int i=0;i<Int32.Parse(number_of_vms_textBox.Text);i++)
            {
                String tmp_virtbuilder_command = virtbuilder.Replace("nodeand#", new_cluster_name_textBox.Text + i.ToString());
                String tmp_virtbuilder_result = sshclient.CreateCommand(tmp_virtbuilder_command).Execute();
                Console.WriteLine(tmp_virtbuilder_result);      
            }
            label19.Text = "completed";
        }
        else
        {
            // some error message popup
        }
    }

编辑:

1)延长超时时间似乎有助于将其进一步扩展到命令中。但是由于某种原因,下载的文件会在下一次图像下载迭代时删除。如果超时通过以下方式延长:sshclient.ConnectionInfo.Timeout = TimeSpan.FromSeconds(1000);  然后,我可以在输出中达到这一点:

[3.2]下载:http://libguestfs.org/download/builder/ubuntu-18.04.xz

[4.7]规划如何构建此图像

[4.7]解压缩

[14.7]调整大小(使用virt-resize)以将磁盘扩展到15.0G

不需要将超时延长到更长的时间,因为这一切都应该很快执行。我只是将其设置为1000秒,以确保这不是主要问题。

2)如果要重新创建预期的输出,请输入:sudo virt-builder centos-7.1 --arch x86_64 -o testc0.img --size 15G --root-password password:toor --firstboot-command'reboot '

进入终端

1 个答案:

答案 0 :(得分:0)

解决方案是使用sshclient.CreateShellStream(),以使ssh api不仅仅因为在shell中执行未返回任何内容而返回。