169 похожих чатов

@Fes0r ты периодически набрасываешь, что не только сущности могут кидать

ивенты. А что это за ивенты, можешь пару кейсов в пример привести?
У меня сейчас 99% ивентов кидается в конструкторах и почти всегда каждому ивенту предшествует персист чего то в базу.
Причём часто именно необходимость кинуть ивент заставляет меня пару сущней добавить, наличие которых так же начинает трекать чё в системе происходит.
Типа на ивент закрытого заказа перед тем как отправить смс, создаётся запись в таблице с текстом смс и адресатом, на вылетевший ивент происходит попытка отправки с записью о результате. Результат тоже может кинуть ивент если он кому то нужен.
Ну то есть ивенты про которые ты говоришь это упрощение этой схемы, типа сообщение "надо отправить смс с таким текстом туда то" и никто нигде это не записал, просто отправили и всё. Или речь о каких то других кейсах?

7 ответов

7 просмотров

ты прост добавил своеобразный durability сообщениям. Можно же просто сообщения сохранять (events, messages) а не под каждый отдельный придумывать свою таблицу

есть доменные ивенты "в духе event sourcing" которые содержат в себя часть стэйта и относятся к отдельным агрегатам, а есть "интеграционные ивенты" (во всяком случае мы у нас их так называем) - "что-то произошло, вот айдишка и время". Если у тебя ивент "надо отправить sms" - то лучше дернуть метод. Ивент это скажем "заказ закрыт". И те кто получают этот ивент точно знают что "заказ закрыт и можно слать нотификашки" Смысл в том что бы ивенты были точкой расширения и позволяли тебе добавлять поведение не меняя ту часть которая ивенты кидает. Ну и я все ивенты пишу в лог - полезно для отладки и супорта

а как последовательность соблюдаешь? ну тоесть не для доменных незачем запариваться за последовательностью, но в логах она была бы очень нелишней

Константин-Грачев Автор вопроса

Я по этой причине "надо отправить" назвал сообщением, а не ивентом. В случае с смс у меня ивент SendSmsRequested называется

никак. compiting consumers + retry on failure

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

Константин-Грачев Автор вопроса

Ну так и есть. Создана запись на N дату -> Запрошена отправка смс -> смс отправлена

Похожие вопросы

Обсуждают сегодня

Anyone here suffers from unexplained aural migraines, who would be up for talking for a bit? Doesn't *have* to be aural, but I am not asking about headaches, I mean actual mi...
Martin Rys
55
Вопрос по WIN32: Насколько я понимаю то все функции win32 привязаны к объектам операционной системы. Например консоль, файл, кисть, окна итд. Следовательно функции win32 упра...
Tommy Vercetti
6
кто-то пользуется компонентами rx ? как их лучше ставить, через OPM? (lazarus)
Iluha Companets
15
В смысле более затратная? Общая стоимость владения лошадью меньше, чем автомобиля. В среднем.
Sergej R
10
подскажите пожалуйста, как мне освободить результат записанный в переменную result? в чем проблема подскажите если МОЖЕТЕ?
Михаил Helper
28
есть тут кто-то , кто только начал изучать си? если проходите курс на степике или как-то сами изучаете, пишите, может, скооперируемся?..
Eule
25
Слушайте, ещё такая интересная задачка. Сделан аудит действий пользователей через триггеры в базе, соответственно каждый пользователь имеет свой логин и пароль в базе. Это пре...
Сергей Бычков
12
Скажите, тут нет проблемы? IMyInterface1 = interface function GetInterface2: IInterface2; ... function TMyInterface.GetInterface2: IInterface2; begin Result := TI...
Ruslan aka DUDE
18
я не магистр хаскеля, но разве не может лейзи тип конвертнуться в не-лейзи запросив вычисление содержимого прям при инициализации?
deadgnom32 λ madao
100
Вопрос. Запускаю сонсольное приложение. Читаю из пайпа его вывод. Если данных нет, то на чтении поток зависает. Отправляю в вывод чучуть текста - нифига. Отправляю ещё чучуть...
Serjone
11
Карта сайта