我有一个执行此操作的控制台应用程序
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 操纵流以使远程操作具有交互性这一事实。也许这就是这个简单的东西不起作用的原因。
尝试使用 xCmd.exe,它是 psexec 的替代品,它将远程输出重定向到您运行代码的本地控制台。我曾尝试混合 JAVA + PSEXEC 非常糟糕的组合。但是在使用 xcmd.exe 时取得了不错的效果,但一个问题是它适用于 32 位操作系统 uptil win 2k8。从 win7 开始,这就不太管用了。
您可以使用 -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