роутеры попало на event.bus (он один). В event bus подключены N подписчиков, они ВСЕ получат данное сообщение.
как сделать независимо?
у тебя есть внутри монолита неймспейс, занимающийся отправкой сообщений. типа как микросервис. ты именно для задач, связанных с смс, создаешь в кролике очередь и в config-е event.sms.bus. и подписываешь хендлеры смс-неймспейса на этот специальный bus. к этому басу и очереди sms подключаешь N консюмеров, они будут все разгребать эту очередь.
с email -ом аналогично. очередь email, в которую с echange-а через fanout придут сообщения + event.email.bus и к нему свои подписчики, работающие в рамках отправки email + N других консюмеров.
если ты начнешь бить монолит на микросеврсиы, то у тебя уже все будет для этого готово. на каждую фугкциональность настроена личная очередь, свой бас и свои хендлеры.
Очень хорошо но мне не надо бить на микросервисы у меня уже разбито это теоритечнские примеры. Там может быть просто запуск команды продолжающей бизнес логику микросервиса. И в вашем варианте мне при создании КАЖДОГО нового обработчика надо думать о шинах и создавать их. С моим костылем я просто создаю обработчик и все работает само. Но спасибо я понял ваш вариант. Он мне не подходит слишком многое можно пролюбить забыть при создании нового хэндлера. Если что мы не используем больше месенджер просто накидали свой со своими хотелками в частности с массовой batch и асинхронной отправкой соощений средствами обычного газла если что из aws sdk с sqs
Обсуждают сегодня