PsExec 重定向输出和命令生成的错误不起作用

问题描述 投票:0回答:2

我有一个执行此操作的控制台应用程序

class Program
{
    static void Main(string[] args)
    {
        Console.WriteLine("out");
        Console.Error.WriteLine("err");
        Environment.ExitCode = 5;
    }
}

当我在 cmd 提示符下运行时,我得到以下信息

C:\>C:\pstools\test\outnerr.exe >C:\pstools\test\out1.log 2>C:\pstools\test\err1.log
C:\>echo %errorlevel%
5
C:\>type C:\pstools\test\out1.log
out
C:\>type C:\pstools\test\err1.log
err
C:\>

这是预期的。

现在如果我在运行窗口中运行它

cmd /c C:\pstools\test\outnerr.exe >C:\pstools\test\out2.log 2>C:\pstools\test\err2.log

这也可以创建 out2.log 和 err2.log。

现在,如果我使用 psexec 来运行它。我想创建一个日志文件。它是在本地机器还是远程机器上创建的并不重要。 所以我运行这个命令

C:\pstools\test\psexec.exe \\127.0.0.1 cmd /c C:\pstools\test\outnerr.exe >C:\pstools\test\out3.log 2>C:\pstools\test\err3.log

从运行窗口执行时不会创建日志文件。但如果从命令提示符运行,同样有效。

我需要在上面更改什么才能从运行窗口创建日志文件?

PS 我在这里和互联网上阅读了很多关于 PsExec 重定向问题的帖子。我知道 PsExec 操纵流以使远程操作具有交互性这一事实。也许这就是这个简单的东西不起作用的原因。

logging cmd psexec io-redirection
2个回答
0
投票

尝试使用 xCmd.exe,它是 psexec 的替代品,它将远程输出重定向到您运行代码的本地控制台。我曾尝试混合 JAVA + PSEXEC 非常糟糕的组合。但是在使用 xcmd.exe 时取得了不错的效果,但一个问题是它适用于 32 位操作系统 uptil win 2k8。从 win7 开始,这就不太管用了。


0
投票

您可以使用 -lo 选项将 PSExec 输出写入文件

新思科技:

psexec \\<machine_ip_address> -u <username> -p <password> -lo <log_filename> <some_command>

例子:

psexec \\192.10.10.69 -u admin -p 12345 -lo paexec.log ipconfig
© www.soinside.com 2019 - 2024. All rights reserved.