请考虑以下代码:
start-job -scriptblock { sleep 10; cmd /c set > c:\env.txt; }
exit
父进程退出后,后台作业将被终止,因此不会发生对cmd.exe的调用。我想写一些类似的代码,这样父母就会立即退出,孩子继续在后台运行。
如果可能的话,我想将所有内容保存在一个脚本中。
请考虑以下代码:
start-job -scriptblock { sleep 10; cmd /c set > c:\env.txt; }
exit
父进程退出后,后台作业将被终止,因此不会发生对cmd.exe的调用。我想写一些类似的代码,这样父母就会立即退出,孩子继续在后台运行。
如果可能的话,我想将所有内容保存在一个脚本中。
你必须开始一个过程:
start-process powershell -ArgumentList "sleep 10; cmd /c set > c:\env.txt" -WindowStyle hidden
你也可以这样做
$a = start-job -scriptblock { sleep 10; cmd /c set > c:\env.txt; }
Register-ObjectEvent -InputObject $a -EventName StateChanged -SourceIdentifier "finished"
$b = Wait-Event -SourceIdentifier "finished"
exit
您的脚本将等待scriptblock的结束完成。
你必须开始一个过程:
start-process powershell -ArgumentList "sleep 10; cmd /c set > c:\env.txt" -WindowStyle hidden
你也可以这样做
$a = start-job -scriptblock { sleep 10; cmd /c set > c:\env.txt; }
Register-ObjectEvent -InputObject $a -EventName StateChanged -SourceIdentifier "finished"
$b = Wait-Event -SourceIdentifier "finished"
exit
您的脚本将等待scriptblock的结束完成。
如果发现使用Invoke-Command能够绕过后台作业因其父级而死亡的限制。好处是语法与start-job几乎相同,因此scriptblock可以保持原样。
start-job -scriptblock { sleep 10; cmd /c set > c:\env.txt; }
只会变成
Invoke-Command -ComputerName . -AsJob -scriptblock { sleep 10; cmd /c set > c:\env.txt; }
并突然幸免于它的父亲的死亡(可能是因为调用命令适合在另一台计算机上运行程序,所以父母可以永远不重要)
如果使用Start-Process,则创建一个将powershell会话作为其父进程的新子进程。如果你杀死powershell父母 处理 从此开始,新进程将成为孤立状态并继续运行。但是,如果你杀了父母的话,它将无法生存 过程树
Start-Process -FilePath notepad.exe
Powershell无法为您在进程树之外启动新的独立进程。但是,这可以在Windows中使用 CreateProcess的 并且此功能通过WMI公开。幸运的是,你可以从powershell调用它:
Invoke-WmiMethod -Class Win32_Process -Name Create -ArgumentList notepad.exe
这样,新进程也将继续运行 过程树 被杀死,因为新进程没有作为父进程的powershell会话,而是WMI主机进程。