(PECL gearman >= 0.6.0)
Wait for activity from one of the job servers
public bool GearmanWorker::wait ( void )
Causes the worker to wait for activity from one of the Gearman job servers when operating in non-blocking I/O mode. On failure, issues a E_WARNING
with the last Gearman error encountered.
Returns:
Returns TRUE
on success or FALSE
on failure.
Examples:
Running worker in non-blocking mode
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 | <?php echo "Starting\n" ; # Create our worker object $worker = new GearmanWorker(); # Make the worker non-blocking $worker ->addOptions(GEARMAN_WORKER_NON_BLOCKING); # Add the default server (localhost, port 4730) $worker ->addServer(); # Add our reverse function $worker ->addFunction( 'reverse' , 'reverse_fn' ); # Try to grab a job while (@ $worker ->work() || $worker ->returnCode() == GEARMAN_IO_WAIT || $worker ->returnCode() == GEARMAN_NO_JOBS) { if ( $worker ->returnCode() == GEARMAN_SUCCESS) continue ; echo "Waiting for next job...\n" ; if (!@ $worker ->wait()) { if ( $worker ->returnCode() == GEARMAN_NO_ACTIVE_FDS) { # We are not connected to any servers, so wait a bit before # trying to reconnect. sleep(5); continue ; } break ; } } echo "Worker Error: " . $worker ->error() . "\n" ; function reverse_fn( $job ) { return strrev ( $job ->workload()); } ?> |
See also:
Please login to continue.