каждый запрос есть обработчик, в конструктор которого передаются репозитории (в конструктор которых передается соединение). Это делается один раз при старте приложения.
Обработчик ничего не знает о базе, у него есть только интерфейс репозитория. Но мне нужно соблюдать консистентность и выполнять все действия в транзакции, выполняя в конце коммит или роллбэк.
Так вот, у меня 2 идеи:
1. Создавать экземпляры обработчика и репозиториев непосредственно перед их запуском и в конструктор передавать репу, в которой вместо соединения транзакция, а после выполнения обработчика коммитить или откатывать
2. Засаживать транзакцию в контекст в начале обработки и вытаскивать его в репозиториях.
Какие бэст практис по этой части? Кто как делает?
П.С. Помимо этого есть похожие вещи с отправкой отложенной задачи или сообщения в кролика, которые должны отправиться только при успехе
Номер 2 тут упоминался как пример. Даже был пример кода, сейчас поищу...
Я обычно второй вариант использую
Можете еще как вариант заменить транзакции на компенсирующие действия
всё это должна обеспечивать реализация репозитория. Иначе она никуда не годится
вот
Обсуждают сегодня