Ну это лечилось тривиально.<div><br><div>Все воркеры запускаются под супервизором (runit), и при старте он проверяет очередь на задачи, маркированные тем же ip, но другим pid, и снимает с них пометку.<br><br><div class="gmail_quote">
6 августа 2012 г., 13:42 пользователь Sergey Leschenko <span dir="ltr"><<a href="mailto:sergle.ua@gmail.com" target="_blank">sergle.ua@gmail.com</a>></span> написал:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
<div class="im">> Сначала делал UPDATE таблицы, а потом выбирал нужные записи.<br>
<br>
</div>Минус этого варианта в том, что если worker умрет, надо вернуть задачи<br>
обратно в очередь.<br>
<br>
В MySQL есть GET_LOCK(name), RELEASE_LOCK(name) которые не привязаны к<br>
таблице, и удаляются при потере соединения.<br>
Читаем задачу, формируем имя лока, пробуем залочить - получилось -<br>
выполняем, не получилось - переходим к следующей задаче.<br>
<span class="HOEnZb"><font color="#888888"><br>
--<br>
Sergey<br>
</font></span><div class="HOEnZb"><div class="h5">--<br>
Moscow.pm mailing list<br>
<a href="mailto:moscow-pm@pm.org">moscow-pm@pm.org</a> | <a href="http://moscow.pm.org" target="_blank">http://moscow.pm.org</a><br>
</div></div></blockquote></div><br></div></div>