Locking seems to be better here
This commit is contained in:
		
					parent
					
						
							
								58880ca518
							
						
					
				
			
			
				commit
				
					
						2372ef7fd5
					
				
			
		
					 2 changed files with 5 additions and 0 deletions
				
			
		
							
								
								
									
										4
									
								
								boot.php
									
										
									
									
									
								
							
							
						
						
									
										4
									
								
								boot.php
									
										
									
									
									
								
							|  | @ -1089,6 +1089,8 @@ function proc_run($cmd) { | |||
| 	$argv = $args; | ||||
| 	array_shift($argv); | ||||
| 
 | ||||
| 	dba::lock('workerqueue'); | ||||
| 
 | ||||
| 	$parameters = json_encode($argv); | ||||
| 	$found = dba::select('workerqueue', array('id'), array('parameter' => $parameters), array('limit' => 1)); | ||||
| 
 | ||||
|  | @ -1096,6 +1098,8 @@ function proc_run($cmd) { | |||
| 		dba::insert('workerqueue', array('parameter' => $parameters, 'created' => $created, 'priority' => $priority)); | ||||
| 	} | ||||
| 
 | ||||
| 	dba::unlock(); | ||||
| 
 | ||||
| 	// Should we quit and wait for the poller to be called as a cronjob?
 | ||||
| 	if ($dont_fork) { | ||||
| 		return; | ||||
|  |  | |||
|  | @ -20,6 +20,7 @@ function pubsubpublish_run(&$argv, &$argc){ | |||
| 			logger("Publish feed to ".$rr["callback_url"], LOGGER_DEBUG); | ||||
| 			proc_run(array('priority' => PRIORITY_HIGH, 'created' => $a->queue['created'], 'dont_fork' => true), | ||||
| 					'include/pubsubpublish.php', (int)$rr["id"]); | ||||
| 			logger("Publish feed to ".$rr["callback_url"].' - done', LOGGER_DEBUG); | ||||
| 		} | ||||
| 	} | ||||
| 
 | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue