Поделиться через


about_Foreach-Parallel

КРАТКОЕ ОПИСАНИЕ

Описывает конструкцию foreach -Parallel языка в рабочем процессе Windows PowerShell.

ПОДРОБНОЕ ОПИСАНИЕ

Параметр Parallel ключевого foreach слова выполняет команды в блоке foreach скрипта один раз для каждого элемента в указанной коллекции.

Элементы в коллекции, такие как диск в коллекции дисков, обрабатываются параллельно. Команды в блоке скрипта выполняются последовательно для каждого элемента в коллекции.

foreach -Parallel действителен только в рабочем процессе Windows PowerShell.

SYNTAX

foreach -Parallel ($<item> in $<collection>) {
    [<Activity1>]
    [<Activity2>]
    ...
}

ПОДРОБНОЕ ОПИСАНИЕ

Как и инструкция foreach в Windows PowerShell, переменная, содержащая коллекцию $<collection>, должна быть определена перед инструкцией foreach -Parallel, но переменная, представляющая текущий элемент $<item>, определена в инструкции foreach -Parallel.

Конструкция foreach -Parallel отличается от ключевого foreach слова и параметра Parallel . Ключевое foreach слово обрабатывает элементы в коллекции в последовательности. Параллельный параметр выполняет команды в блоке скриптов параллельно. В блок скрипта можно заключить блок параллельных foreach -Parallel скриптов.

Целевые компьютеры в рабочем процессе, например те, которые указаны общим параметром рабочего процесса PSComputerName , всегда обрабатываются параллельно. Для этой цели не нужно указывать ключевое foreach -Parallel слово.

Примеры

Следующий рабочий процесс содержит инструкцию foreach -Parallel , которая обрабатывает диски, Get-Disk которые получает действие. Команды в блоке foreach -Parallel скрипта выполняются последовательно, но выполняются параллельно на дисках. Диски могут обрабатываться одновременно и в любом порядке.

workflow Test-Workflow {
    $Disks = Get-Disk

    # The disks are processed in parallel.
    foreach -Parallel ($Disk in $Disks)
    {
        # The commands run sequentially on each disk.
        $DiskPath = $Disk.Path
        $Disk | Initialize-Disk
        Set-Disk -Path $DiskPath
    }
}

В этой версии рабочего процесса Get-ProcessGet-Service команды выполняются параллельно. Функция рабочего процесса продолжает foreach -Parallel цикл, в котором команды выполняются последовательно, но они выполняются на дисках параллельно. Параллельные команды и foreach -Parallel цикл выполняются параллельно.

workflow Test-Workflow {
    #Run commands in parallel.
    parallel
    {
        Get-Process
        Get-Service
    }

   $Disks = Get-Disk

   # The disks are processed in parallel.
   foreach -Parallel ($Disk in $Disks)
   {
       # The commands run in parallel on each disk.
       parallel
       {
           Initialize-Disk
           inlinescript {.\Get-DiskInventory}
       }
   }
}

См. также