1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071 |
- <?php
- namespace Predis\Pipeline;
- use SplQueue;
- use Predis\CommunicationException;
- use Predis\Connection\ConnectionInterface;
- class SafeClusterExecutor implements PipelineExecutorInterface
- {
-
- public function execute(ConnectionInterface $connection, SplQueue $commands)
- {
- $size = count($commands);
- $values = array();
- $connectionExceptions = array();
- foreach ($commands as $command) {
- $cmdConnection = $connection->getConnection($command);
- if (isset($connectionExceptions[spl_object_hash($cmdConnection)])) {
- continue;
- }
- try {
- $cmdConnection->writeCommand($command);
- } catch (CommunicationException $exception) {
- $connectionExceptions[spl_object_hash($cmdConnection)] = $exception;
- }
- }
- for ($i = 0; $i < $size; $i++) {
- $command = $commands->dequeue();
- $cmdConnection = $connection->getConnection($command);
- $connectionObjectHash = spl_object_hash($cmdConnection);
- if (isset($connectionExceptions[$connectionObjectHash])) {
- $values[$i] = $connectionExceptions[$connectionObjectHash];
- continue;
- }
- try {
- $values[$i] = $cmdConnection->readResponse($command);
- } catch (CommunicationException $exception) {
- $values[$i] = $exception;
- $connectionExceptions[$connectionObjectHash] = $exception;
- }
- }
- return $values;
- }
- }
|