GearmanWorker::wait

(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
$workernew 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:

GearmanWorker::work() -

doc_php
2025-01-10 15:47:30
Comments
Leave a Comment

Please login to continue.