4

尝试使用 PsExec 远程运行 .NET 命令行工具时,我遇到了一个奇怪的问题。

  1. 从命令行运行 PsExec 时,它可以正常运行并完成。

  2. 从控制台应用程序运行它时(创建一个进程,运行 PsExec.exe 并为其提供必要的参数)——它运行正常。

  3. 从我们用于运行不同任务的内部自定义工具运行它时,它要么超时,要么无法成功完成。

这是我正在使用的代码:

Process p = new Process();

p.StartInfo.FileName = @"C:\PsExec.exe";
p.StartInfo.RedirectStandardOutput = true;
p.StartInfo.UseShellExecute = false;
p.StartInfo.CreateNoWindow = true;

string arg = "-snapshot -display C:\*.msi -s";

p.StartInfo.Arguments = @"\\10.161.203.106 -u user -p pwd -cf C:\FVT.exe " + arg;

Logger.Info(this, "Starting process");

p.Start();
var ended = p.WaitForExit(60 * 1000);

if (!ended)
{
    throw new Exception("Process timed out.");
}

Logger.Info(this, "Process ended");

using (StreamReader sr = p.StandardOutput)
{
    string buffer = sr.ReadToEnd();
    Logger.Info(this, buffer);
}

此代码在 cmd 行或独立应用程序中运行良好!

我不知道这里还有什么问题。

我们的内部工具会生成一个新线程并在其中运行此代码。

更新:

命令行窗口中的命令行 + args - 工作。相同的 cmd + args,作为带有 RedirectOutput 的进程运行 - 暂停并在超时时返回。

这可能是 .NET 中的错误吗?(这发生在其他程序、批处理文件等)。

4

2 回答 2

4

尝试将 -accepteula 添加到 psexec 的参数中

于 2012-09-27T09:18:04.783 回答
2

我不知道错误什么,但我有一种预感,如果你重定向 stderr ( RedirectStandardError = true) 并读取 stderr 流(就像你对 stdout 所做的那样),它会告诉你。或者,在调试离开时CreateNoWindow = false,您可能会看到控制台消息(特别是如果它正在等待按键;否则它可能会消失得太快而无法注意到)。

请注意,如果进程没有终止,您可能需要在 stdout/stderr 上设置异步读取器。您可以在额外的线程上或通过OutputDataReceived/ErrorDataReceived事件(您也需要设置)EnableRaisingEvents来执行此操作true


如果还是不行;您可以尝试使用UseShellExecute=true. 这意味着您将无法重定向 IO,因此您可能必须使用>/ >>etc 将输出通过管道传输到文件(最好在 temp 中),然后读取文件。

于 2011-07-25T07:03:21.770 回答