2017 © Pedro Peláez
 

library process-iterator

Sequential way to run Symfony Processes in parallel

image

console-helpers/process-iterator

Sequential way to run Symfony Processes in parallel

  • Wednesday, January 31, 2018
  • by aik099
  • Repository
  • 1 Watchers
  • 0 Stars
  • 9,725 Installations
  • PHP
  • 0 Dependents
  • 0 Suggesters
  • 1 Forks
  • 0 Open issues
  • 2 Versions
  • 5 % Grown

The README.md

ProcessIterator

CI codecov Scrutinizer Code Quality, (*1)

Latest Stable Version Total Downloads License, (*2)

ProcessIterator is a PHP class, that allows writing sequential code to handle processes, that run in parallel., (*3)

This is a modified version of the FutureIterator class from Phabricator project adapted to with with Symfony Process component., (*4)

Installation

  • execute this command to add dependencies: php composer.phar require console-helpers/process-iterator:dev-master

Usage

IMPORTANT: Keys are preserved, but the order of elements is not. Iteration is done over the processes in the order they are executed, so the fastest process is the one you'll get first. This allows you to start doing followup processing as soon as possible., (*5)

<?php

use ConsoleHelpers\ProcessIterator\ProcessIterator;
use Symfony\Component\Process\Process;

$processes = array(
    'a.txt' => new Process('wc -c a.txt'),
    'b.txt' => new Process('wc -c b.txt'),
    'c.txt' => new Process('wc -c c.txt'),
);


// All of the processes will be started at once, when "foreach" line is executed.
$process_iterator = new ProcessIterator($processes);

foreach ($process_iterator as $key => $process) {
    $stderr = $process->getErrorOutput();
    $stdout = $process->getOutput();
    do_some_processing($stdout);
}


// Will only run 2 processes in parallel at a time.
$process_iterator = new ProcessIterator($processes);
$process_iterator->limit(2);

foreach ($process_iterator as $key => $process) {
    $stderr = $process->getErrorOutput();
    $stdout = $process->getOutput();
    do_some_processing($stdout);
}


// Will run all processes in parallel. The $processes array can be inspected later 
// to see execution results.
$process_iterator = new ProcessIterator($processes);
$process_iterator->runAll();


// Allows to add more processes in real time as they are processed.
$process_iterator = new ProcessIterator($processes);

foreach ($process_iterator as $key => $process) {
    $stderr = $process->getErrorOutput();
    $stdout = $process->getOutput();
    do_some_processing($stdout);

    if ( $key === 'b.txt' ) {
        $process_iterator->addProcess(
            new Process('wc -c d.txt'),
            'd.txt'
        );
    }
}


// Show "processing ..." message at if no process was finished executing after 
// given time has passed. This can happen several times as well.
$process_iterator = new ProcessIterator($processes);
$process_iterator->setUpdateInterval(1);

foreach ($process_iterator as $key => $process) {
    if ($process === null) {
        echo "Still working...\n";
    }
    else {
        $stderr = $process->getErrorOutput();
        $stdout = $process->getOutput();
        do_some_processing($stdout);
    }
}


// Safe process exception detection. When exception happens during process 
// execution it's recorded and that process is immediately yielded. Then
// the $process_iterator->getProcessException() method can be used to 
// handle it gracefully (e.g. re-add back to queue).
$process_iterator = new ProcessIterator($processes);

foreach ($process_iterator as $key => $process) {
    $process_exception = $process_iterator->getException();

    if ( $process_exception instanceof ProcessTimedOutException ) {
        echo "The $key process timed out.\n";
    }
    elseif ( $process_exception instanceof ProcessFailedException ) {
        echo "The $key process has failed.\n";
    }
    else {
        $stderr = $process->getErrorOutput();
        $stdout = $process->getOutput();
        do_some_processing($stdout);
    }
}

Contributing

See CONTRIBUTING file., (*6)

License

ProcessIterator is released under the BSD-3-Clause License. See the bundled LICENSE file for details., (*7)

The Versions

31/01 2018

dev-master

9999999-dev

Sequential way to run Symfony Processes in parallel

  Sources   Download

BSD-3-Clause BSD 3-Clause

The Requires

 

The Development Requires

by Alexander Obuhovich

symfony iterator process parallel

05/03 2016

v1.0.0

1.0.0.0

Sequential way to run Symfony Processes in parallel

  Sources   Download

BSD 3-Clause

The Requires

 

The Development Requires

by Alexander Obuhovich

symfony iterator process parallel