Вот мы на скорую руку создали проект на AR (ActeveRecord) запросы через него, запись и обновление. Для старта нового проекта я считаю это вполне норм, при том, что проект может не взлететь.
Но вот проект живет, модели AR распухают логикой. Растет база, вместе с ней объемы обрабатываемой информации. И нужно уже задумываться, как логику вынести из AR (behaviors, AfterSave, BeforeSave) в первую очередь, чтоб её можно было применять при batchInsert и batchUpdate.
Небольшое отступление, по поводу логики, примеры:
- Изменился статус заказа, нужно отправить уведомления на почту, телеграм и тп. Записать в историю изменения суммы заказа, статуса.
- Обновить/удалить кэш или обновить индекс в elasticSearch
- Отправить на модерацию данные
- И все тому подобное
---
Есть мысли, что нужно это все вынести в обработчики и события, например какой то класс занимается обработкой измененных данных (сравнивает старые данные с новыми) и создает события, причем выполнения действий по событиям должны обрабатываться где то в очереди, в отдельно, чтоб текущую задачу по batchInsert и batchUpdate в несколько тысяч записей это не тормозило.
Но как это должно выглядеть архитектурно, какие нюансы и подводные камни?
Думаю я не первый кто этим вопросом задался, и уже есть какие то архитектурные решения.
Хотелось бы увидеть какие то примеры, потому что на словах это все просто, создай сервис, добавь репозиторий, там же наблюдателей. Но на практике, без опыта - это не просто