ивенты. А что это за ивенты, можешь пару кейсов в пример привести?
У меня сейчас 99% ивентов кидается в конструкторах и почти всегда каждому ивенту предшествует персист чего то в базу.
Причём часто именно необходимость кинуть ивент заставляет меня пару сущней добавить, наличие которых так же начинает трекать чё в системе происходит.
Типа на ивент закрытого заказа перед тем как отправить смс, создаётся запись в таблице с текстом смс и адресатом, на вылетевший ивент происходит попытка отправки с записью о результате. Результат тоже может кинуть ивент если он кому то нужен.
Ну то есть ивенты про которые ты говоришь это упрощение этой схемы, типа сообщение "надо отправить смс с таким текстом туда то" и никто нигде это не записал, просто отправили и всё. Или речь о каких то других кейсах?
ты прост добавил своеобразный durability сообщениям. Можно же просто сообщения сохранять (events, messages) а не под каждый отдельный придумывать свою таблицу
есть доменные ивенты "в духе event sourcing" которые содержат в себя часть стэйта и относятся к отдельным агрегатам, а есть "интеграционные ивенты" (во всяком случае мы у нас их так называем) - "что-то произошло, вот айдишка и время". Если у тебя ивент "надо отправить sms" - то лучше дернуть метод. Ивент это скажем "заказ закрыт". И те кто получают этот ивент точно знают что "заказ закрыт и можно слать нотификашки" Смысл в том что бы ивенты были точкой расширения и позволяли тебе добавлять поведение не меняя ту часть которая ивенты кидает. Ну и я все ивенты пишу в лог - полезно для отладки и супорта
а как последовательность соблюдаешь? ну тоесть не для доменных незачем запариваться за последовательностью, но в логах она была бы очень нелишней
Я по этой причине "надо отправить" назвал сообщением, а не ивентом. В случае с смс у меня ивент SendSmsRequested называется
никак. compiting consumers + retry on failure
опять же у тебя штука которая отправку sms запрашивает* что-то знает о sms. Если ты хочешь тип в бэкграунде это делать - то почему нет. Но я обычно стараюсь такие вещи разруливать после ивента о том что такая-то операция завершилась. Что бы все второстепенное убрать
Ну так и есть. Создана запись на N дату -> Запрошена отправка смс -> смс отправлена
Обсуждают сегодня