Atf*_*Atf 6 powershell powershell-4.0 powershell-workflow
我试图触发一个PowerShell工作流程,它应该并行旋转10个线程.我正在使用PS版本4.代码 -
Workflow CreateVMs
{
$i = 0
#somecodehere...
foreach -parallel -throttlelimit 10($i in 0..30)
{
#somemorecodehere...
# INVOKING BATCH FILE USING POWERSHELL
}
}
Run Code Online (Sandbox Code Playgroud)
我在内联脚本中使用powershell调用批处理文件.我在任务管理器中观察到的是,一次只有5个线程处于活动状态 -
可能是下一个获取的线程只有五个中的一个完成.我从未见过超过5 ps的实例.但是,当我检查每个用户允许的ps会话时,它远远超过5.
如何在PS工作流程中并行旋转10个PS线程.我在这里错过了什么?
给出以下示例脚本:
Workflow Test-Workflow
{
foreach -Parallel -ThrottleLimit 10 ( $Number in 1..20 )
{
$RandomSeconds = Get-Random -Minimum 10 -Maximum 60
InlineScript
{
$String = '{0:s}: Starting number {1:D2} for {2:D2} seconds' -f (Get-Date),$Using:Number,$Using:RandomSeconds
Write-Host -Object $String
}
Start-Sleep -Seconds $RandomSeconds
InlineScript
{
$String = '{0:s}: Stopping number {1:D2} after {2:D2} seconds' -f (Get-Date),$Using:Number,$Using:RandomSeconds
Write-Host -Object $String
}
}
}
Test-Workflow
Run Code Online (Sandbox Code Playgroud)
您将得到类似于以下内容的输出:
2017-11-28T13:27:34: Starting number 09 for 25 seconds
2017-11-28T13:27:34: Starting number 10 for 36 seconds
2017-11-28T13:27:34: Starting number 08 for 53 seconds
2017-11-28T13:27:35: Starting number 06 for 17 seconds
2017-11-28T13:27:35: Starting number 07 for 28 seconds
2017-11-28T13:27:35: Starting number 05 for 33 seconds
2017-11-28T13:27:35: Starting number 04 for 49 seconds
2017-11-28T13:27:35: Starting number 02 for 18 seconds
2017-11-28T13:27:35: Starting number 03 for 47 seconds
2017-11-28T13:27:35: Starting number 01 for 45 seconds
2017-11-28T13:27:52: Stopping number 06 after 17 seconds
2017-11-28T13:27:55: Starting number 11 for 49 seconds
2017-11-28T13:27:55: Stopping number 02 after 18 seconds
2017-11-28T13:27:55: Starting number 12 for 55 seconds
2017-11-28T13:28:00: Stopping number 09 after 25 seconds
2017-11-28T13:28:00: Starting number 13 for 37 seconds
2017-11-28T13:28:03: Stopping number 07 after 28 seconds
2017-11-28T13:28:03: Starting number 14 for 46 seconds
2017-11-28T13:28:08: Stopping number 05 after 33 seconds
2017-11-28T13:28:08: Starting number 15 for 48 seconds
2017-11-28T13:28:11: Stopping number 10 after 36 seconds
2017-11-28T13:28:11: Starting number 16 for 57 seconds
2017-11-28T13:28:21: Stopping number 01 after 45 seconds
2017-11-28T13:28:21: Starting number 17 for 22 seconds
2017-11-28T13:28:22: Stopping number 03 after 47 seconds
2017-11-28T13:28:22: Starting number 18 for 39 seconds
2017-11-28T13:28:24: Stopping number 04 after 49 seconds
2017-11-28T13:28:24: Starting number 19 for 34 seconds
2017-11-28T13:28:28: Stopping number 08 after 53 seconds
2017-11-28T13:28:28: Starting number 20 for 58 seconds
2017-11-28T13:28:37: Stopping number 13 after 37 seconds
2017-11-28T13:28:43: Stopping number 17 after 22 seconds
2017-11-28T13:28:44: Stopping number 11 after 49 seconds
2017-11-28T13:28:49: Stopping number 14 after 46 seconds
2017-11-28T13:28:50: Stopping number 12 after 55 seconds
2017-11-28T13:28:56: Stopping number 15 after 48 seconds
2017-11-28T13:28:58: Stopping number 19 after 34 seconds
2017-11-28T13:29:01: Stopping number 18 after 39 seconds
2017-11-28T13:29:08: Stopping number 16 after 57 seconds
2017-11-28T13:29:26: Stopping number 20 after 58 seconds
Run Code Online (Sandbox Code Playgroud)
正如您从输出中看到的,尽管我没有运行 10 个 powershell.exe 实例,但循环的 10 个实例正在同时运行。您可以InlineScript像上面的示例一样使用来直观地查看工作流程何时启动和/或停止循环实例。
| 归档时间: |
|
| 查看次数: |
655 次 |
| 最近记录: |