Musisz odwrócić zamówienie, aby nie było okna czasowego.
Konsumencki POP (każdy konsument ma unikalny $consumer_id)
Update queue
set last_pop = '$consumer_id'
where last_pop is null
order by id limit 1;
$job =
Select * from queue
where last_pop = '$consumer_id'
order by id desc
limit 1;
Dostawca PUSH
insert into queue
(id, last_pop, ...)
values
(NULL, NULL, ...);
Kolejka jest uporządkowana w czasie według kolumny id i przypisana podczas POP do identyfikatora konsumenta.