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

Всем привет, ребят, у нас тут появилась довольно геморная задача

- для всех изменямых сущностей в системе вести "журнал событий", хранить типа какой пользователь, во сколько и что сделал с сущностью, что изменил в ней (некоторые параметры сущностей у нас хранятся в виде jsonb-полей), всю эту жесть отображать на фронте в одной таблице с фильтрациями по типам сущностей, пользователям и действиям) Никто не сталкивался с подобными задачами? Мб есть какая-нибудь статья, которую мне можно покурить? Одна из проблем заключается в том, что модели сущностей (читай- поля таблиц) у нас могут меняться, и вот эта вот херня с журналом должна быть готова к таким изменениям и тоже их поддерживать. Используем sequelize + postgresql

2 ответов

11 просмотров

хранить все события это про event sourcing и смежные архитектуры/подходы типа CQRS. https://microservices.io/patterns/data/event-sourcing.html

Была такая же задача В molecular решилась довольно просто: подпиской на ивенты создания/удаления/обновления всех сущностей При наступлении ивента идёт сверка с базой, текущими настройками, с целью понять, надо ли журналировать изменение Думаю простота реализации сильно зависит от либы/фреймворка, на котором построен проект

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

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

Всем привет, написал код ниже, но он выдает сегфолт, в чем причина? #include <stdio.h> #include <stdlib.h> #include <string.h> struct product { char *name; float price; };...
buzz базз
70
Хотел бы спросить у знающих, правильную ли я выбрал книгу для начала изучения ассемблера Юрова В.И ? Или есть более лучшие книги для начала обучения?
Botsman
31
Здравствуйте. Задача состоит в том, чтобы сделать real-time чат в мобильном приложении. После передачи сообщения пользователем через веб-сокеты, для основного и долговременног...
🐾
5
Всем доброго дня, ребят подскажите пожалуйста, если в курсе по ассемблеру используется MASM32, могу ли я использовать FASM? В чем явная разница и будет ли у меня все работать?
Botsman
17
Книга Юрова В.И пойдёт для обучения?
Botsman
24
$params = [ 'formid' => 'feedbackForm', 'formTpl' => '@CODE: <form class="form-validate" data-id="ajax_form"> <fieldset class="margin-bottom-md"> ...
Pathologic
1
Люди добрые, помогите с идеями, потому что свои закончились. У клиента падает софтина в момент инициализации модуля OtlEventMonitor на RegisterWindowMessage('Gp/OtlTaskEvents/...
Михаил Усков
7
Тут просто дело в том, что я не могу сейчас дать такие подробности из за того что рассчитать это всё нереально. Этого проекта который я хочу сделать ещё даже не существует) И ...
🐾
8
это разве не аналог jvm и той же запускаемой машины на python?
Digital Infinite
10
> Примечательно, что новый владелец удаляет из GitHub любые жалобы, указывающие на подозрительную активность или смену владельца, и, видимо, рассчитывает на то, что пользовате...
Alex Sherbakov
2
Карта сайта