RabbitMQ tutorial 4 — Тематики

от автора

Продолжаю серию перевода уроков с официального сайта. Примеры будут на php, но их можно реализовать на большинстве популярных ЯП.
В предыдущей статье мы усовершенствовали системы логирования. Вместо точки доступа fanout (которая подходит только для элементарной трансляции сообщений), мы использовали direct — и получили возможность получать сообщения через определенные выборки.
Хоть direct и усовершенствовал нашу систему, он всё-таки имеет недостаток — он не может составить маршрут(routing) по нескольким критериям.
Например, нам понадобилось разделять логи не только по его типу важности, но и по источнику лога. Вы наверное встречали такую концепцию в unix инструменте syslog, которые различает логи по его типу важности(info/warn/crit…) и по его объекту (auth/cron/kern…).
Мы получаем гибкость в запросе. Например, мы может получить все логи с типом error, пришедшие из ‘cron’-а, и все логи пришедшие с ‘kern’. Для того, чтобы реализовать это в нашей системе логирования, изучим точку доступа — topic.

Topic

Сообщения, отправляемые в точку доступа topic, не могут отсылаться с произвольным ключом routing_key — это должен быть список слов, разделенный точкой. Слова могут быть любыми, но обычно они ассоциируются с какими-либо свойствами сообщения. Вот примеры правильного routing_key: «stock.usd.nyse», «nyse.vmw», «quick.orange.rabbit». Длина ключа не должна превышать 255 байт.

ссылка на оригинал статьи http://habrahabr.ru/post/201178/


Комментарии

Добавить комментарий

Ваш адрес email не будет опубликован. Обязательные поля помечены *