2016-08-19 3 views
0

У меня есть небольшое приложение, которое потребляет сообщения от RabbitMQ.Производительность между while (1) и блокирующим вызовом

В настоящее время его цикл (1), он вызывает «Dequeue» и ждет его навсегда для сообщения, а затем обрабатывает сообщение.

Так что я думал, что это блокирующий вызов «Dequeue» - хорошая идея или будет немедленный DequeueNoWait (ничего не возвращается сразу) не лучше или даже может быть «Dequeue» с таймаутом. Конечно, было бы гораздо больше, пока итерации.

спасибо

+1

Ожидание вращения должно использоваться только в том случае, если ожидаемое время ожидания «очень короткое». Вы эффективно держите CPU занятым ни с чем. В случае, когда это дешевле, чем переключение контекста на другой поток, это может быть хорошей идеей. Если вы долго ждали, это не так. Не зная больше о вашем случае, трудно дать хороший совет. У вас есть асинхронные версии этих методов? –

+0

К сожалению, у него нет асинхронизации. Это было бы очень приятно. – Pintac

+0

@ Pintac очень легко написать асинхронную оболочку. Очевидно, что поток I/O должен быть принесен в жертву. Но это нормально/приемлемо и распространено в EDA (Event Driven Architecture, например node.js). Таким образом, идея асинхронной обертки - это больше о стиле программирования и простоте использования, чем производительности или ресурсе. – pid

ответ

0

Это классическая проблема. Лучшее, что вы можете сделать, это использовать блокировку Dequeue() с таймаутом, чтобы можно было обрабатывать больше, чем просто сообщения RabbitMQ. Например:

  • на Unix/Linux также системы обработки сигналов, таких как SIGHUP или SIGINT
  • на терминальных команд также принимают пользовательский ввод, чтобы вырваться из цикла с сообщением «Нажмите ESC, чтобы выйти ...» или что-то подобное
  • , если есть и другие входные потоки обрабатывают те, тоже в том же потоке

Тайм-аут должен быть установлен на основе того, что вы ожидаете. Для некоторых системных сигналов очень строгие таймауты даются до того, как процесс выйдет из воды. Для консольных приложений человеческие пользователи не будут замечать тайм-аут 150 мс, он по-прежнему будет смотреть на них практически в реальном времени.

Если вы не блокируете и не используете таймаут, процессор будет потреблять ненужные ресурсы, чтобы как можно быстрее прокручивать их, без каких-либо преимуществ. Что-то вроде этого целесообразно только тогда, когда время очень важно. Но тогда вы бы не использовали RabbitMQ.


EDIT: больше о тайм-аута

А 1 второй тайм-аута делает не означает, что сообщение подобран в 1 секунду. Сообщения по-прежнему обрабатываются мгновенно, по мере их поступления. Тайм-аут означает, что ПРОЧИЕ задачи выполняются с максимальной задержкой в ​​1 секунду (средняя задержка составляет половину таймаута, поэтому 0,5 секунды).

+0

Да, я склонялся к таймауту. В моем случае это задача обслуживания, на которую никто не смотрит, и если она занимает 1 с до того, как сообщение будет поднято, что в порядке, не спешите :-) – Pintac

+0

Yip его больше всего будет ждать сообщения. – Pintac