Понять преимущества, недостатки и простоту применения шаблона CQRS в Springboot.
Понять преимущества, недостатки и простоту применения шаблона CQRS в Springboot.

Разделение ответственности за запросы команд (CQRS) — это мощный архитектурный шаблон, который разделяет ответственность за обработку команд и запросов в программной системе. Разделив эти проблемы, CQRS Улучшает масштабируемость, ремонтопригодность и гибкость. В этой статье мы углубимся в CQRS модели, обсудим ее преимущества и недостатки и предоставим возможность ее использования. Spring Boot полный случай.

Что такое CQRS?

CQRS — это аббревиатура от «Разделение ответственности за запросы команд». Это шаблон, разделяющий операции чтения данных (запросы) и записи данных (команды). В системе на основе CQRS обычно задействованы следующие компоненты:

  • Command:представляет собой изменениесистемаданныеиздействовать.Команда отвечает за создание、Обновите или удалите данные.
  • Query:Выражает изсистема Поискданныеиздействовать.Запрос отвечает за чтениеданныебез измененияданные。
  • Command Handler:Обрабатывать и выполнять команды,Изменить статус системы.
  • Query Handler:отсистема Поискданные并以合适из格式返回данныедля обработки запросов。

Преимущества CQRS:

1. Масштабируемость

CQRS позволяет независимо масштабировать операции чтения и записи. Это особенно полезно в системах с большой разницей в нагрузках чтения и записи. Вы можете выделить больше ресурсов для оптимизации производительности запросов, сохраняя при этом эффективность операций записи.

2. Гибкость

Поскольку команды и запросы разделены,Таким образом, можно сохранять и извлекать стратегии независимо. Когда речь идет о различных технологиях хранения данных или оптимизации производительности,Эта гибкость особенно полезна.

3. Улучшение ремонтопригодности

CQRS упрощает базу кода, разделяя задачи. Такое разделение приводит к более чистому и удобному в обслуживании коду, поскольку команды и запросы не мешают друг другу.

4. Повышение безопасности

CQRS позволяет применять различные механизмы безопасности для операций чтения и записи. Вы можете установить более строгие меры безопасности для команд, чтобы гарантировать, что только авторизованные пользователи смогут вносить изменения.

Недостатки CQRS:

1. Повышенная сложность

Внедрение CQRS усложняет систему. Вам необходимо управлять потоком данных между моделями команд и запросов, возможно, дублируя данные для разных моделей.

2. Маршрут обучения

Разработчики, незнакомые с CQRS, могут столкнуться с проблемами повторного обучения при использовании этого шаблона. Понимание концепций и правильная реализация их в проектах может оказаться непростой задачей.

3. Конечная последовательность

CQRS может привести к возможным проблемам с согласованностью, когда модель запроса может не сразу отражать последние изменения, внесенные командой. Обработка этого несоответствия требует осторожного обращения и синхронизации.

CQRS в Spring Boot: простой пример

Давайтеиспользовать Spring Boot приложение для иллюстрации CQRS управление задачами. Мы создадим базовую реализацию с независимыми моделями команд и запросов. Вы можете расширить этот пример, чтобы применить его к более сложным сценариям.

Класс сущности команды:

Язык кода:javascript
копировать
@Entity
public class Task {
    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    private Long id;
    private String title;
    private boolean completed;

    // Constructors, getters, and setters
}

Commandмодуль:CreateTaskCommand

Язык кода:javascript
копировать
public class CreateTaskCommand {
    private String title;

    // Getter and setter for title
}

Command Handler:TaskCommandHandler

Язык кода:javascript
копировать
@Service
public class TaskCommandHandler {
    @Autowired
    private TaskRepository taskRepository;

    @Transactional
    public Long handle(CreateTaskCommand command) {
        Task task = new Task();
        task.setTitle(command.getTitle());
        task.setCompleted(false);
        taskRepository.save(task);
        return task.getId();
    }
}

Запросdto:TaskDTO

Язык кода:javascript
копировать
public class TaskDTO {
    private Long id;
    private String title;
    private boolean completed;

    // Constructors, getters, and setters
}

ЗапросHandler:TaskQueryHandler

Язык кода:javascript
копировать
@Service
public class TaskQueryHandler {
    @Autowired
    private TaskRepository taskRepository;

    public List<TaskDTO> getAllTasks() {
        List<Task> tasks = taskRepository.findAll();
        return tasks.stream()
                .map(task -> new TaskDTO(task.getId(), task.getTitle(), task.isCompleted()))
                .collect(Collectors.toList());
    }
}

Rset API:TaskController

Язык кода:javascript
копировать
@RestController
@RequestMapping("/tasks")
public class TaskController {
    @Autowired
    private TaskCommandHandler commandHandler;
    @Autowired
    private TaskQueryHandler queryHandler;

    @PostMapping
    public Long createTask(@RequestBody CreateTaskCommand command) {
        return commandHandler.handle(command);
    }

    @GetMapping
    public List<TaskDTO> getAllTasks() {
        return queryHandler.getAllTasks();
    }
}

этот Spring Boot Приложение проиллюстрировано разделением модели команд и модели запросов и предоставлением отдельных обработчиков для каждой модели. CQRS основные понятия. Вы можете использовать POST Запрос Создание задач,использовать GET Запрос на получение списка задач.

Вызов API-теста

ты можешьиспользовать这些 cURL команда с Spring Boot Взаимодействуйте с приложением и убедитесь, что оно обрабатывается правильно. CQRS действовать.

использовать CURL Создание задач

Язык кода:javascript
копировать
curl -X POST -H "Content-Type: application/json" -d '{"title":"Task 1"}' http://localhost:8080/tasks

Эта команда отправляет POST Запрос на создание задачи под названием " 1 дюйм. Новая задача. При необходимости измените название. использовать cURL Получить все задачи

Язык кода:javascript
копировать
curl http://localhost:8080/tasks

Эта команда отправляет GET Запрос на получение списка всех задач.

CQRS да Мощный шаблон, который можно применять к более сложным сценариям, таким как источник событий и распределенная система. Хотя это имеет свои преимущества, при решении вопроса о том, стоит ли в проекте использовать CQRS При этом необходимо учитывать повышенную сложность и возможную согласованность. Короче говоря, CQRS Это ценный шаблон, который может улучшить масштабируемость, удобство обслуживания и гибкость системы. В этой статье используется простой Spring Boot Пример: изучить его плюсы и минусы, а также простоту использования. Если вы хотите использовать его в конкретном проекте, вы можете обратиться к некоторым проектам, которые действительно находятся в сети. Проведите более полный анализ и оценку этого.

boy illustration
Углубленный анализ переполнения памяти CUDA: OutOfMemoryError: CUDA не хватает памяти. Попыталась выделить 3,21 Ги Б (GPU 0; всего 8,00 Ги Б).
boy illustration
[Решено] ошибка установки conda. Среда решения: не удалось выполнить первоначальное зависание. Повторная попытка с помощью файла (графическое руководство).
boy illustration
Прочитайте нейросетевую модель Трансформера в одной статье
boy illustration
.ART Теплые зимние предложения уже открыты
boy illustration
Сравнительная таблица описания кодов ошибок Amap
boy illustration
Уведомление о последних правилах Points Mall в декабре 2022 года.
boy illustration
Даже новички могут быстро приступить к работе с легким сервером приложений.
boy illustration
Взгляд на RSAC 2024|Защита конфиденциальности в эпоху больших моделей
boy illustration
Вы используете ИИ каждый день и до сих пор не знаете, как ИИ дает обратную связь? Одна статья для понимания реализации в коде Python общих функций потерь генеративных моделей + анализ принципов расчета.
boy illustration
Используйте (внутренний) почтовый ящик для образовательных учреждений, чтобы использовать Microsoft Family Bucket (1T дискового пространства на одном диске и версию Office 365 для образовательных учреждений)
boy illustration
Руководство по началу работы с оперативным проектом (7) Практическое сочетание оперативного письма — оперативного письма на основе интеллектуальной системы вопросов и ответов службы поддержки клиентов
boy illustration
[docker] Версия сервера «Чтение 3» — создайте свою собственную программу чтения веб-текста
boy illustration
Обзор Cloud-init и этапы создания в рамках PVE
boy illustration
Корпоративные пользователи используют пакет регистрационных ресурсов для регистрации ICP для веб-сайта и активации оплаты WeChat H5 (с кодом платежного узла версии API V3)
boy illustration
Подробное объяснение таких показателей производительности с высоким уровнем параллелизма, как QPS, TPS, RT и пропускная способность.
boy illustration
Удачи в конкурсе Python Essay Challenge, станьте первым, кто испытает новую функцию сообщества [Запускать блоки кода онлайн] и выиграйте множество изысканных подарков!
boy illustration
[Техническая посадка травы] Кровавая рвота и отделка позволяют вам необычным образом ощипывать гусиные перья! Не распространяйте информацию! ! !
boy illustration
[Официальное ограниченное по времени мероприятие] Сейчас ноябрь, напишите и получите приз
boy illustration
Прочтите это в одной статье: Учебник для няни по созданию сервера Huanshou Parlu на базе CVM-сервера.
boy illustration
Cloud Native | Что такое CRD (настраиваемые определения ресурсов) в K8s?
boy illustration
Как использовать Cloudflare CDN для настройки узла (CF самостоятельно выбирает IP) Гонконг, Китай/Азия узел/сводка и рекомендации внутреннего высокоскоростного IP-сегмента
boy illustration
Дополнительные правила вознаграждения амбассадоров акции в марте 2023 г.
boy illustration
Можно ли открыть частный сервер Phantom Beast Palu одним щелчком мыши? Супер простой урок для начинающих! (Прилагается метод обновления сервера)
boy illustration
[Играйте с Phantom Beast Palu] Обновите игровой сервер Phantom Beast Pallu одним щелчком мыши
boy illustration
Maotouhu делится: последний доступный внутри страны адрес склада исходного образа Docker 2024 года (обновлено 1 декабря)
boy illustration
Кодирование Base64 в MultipartFile
boy illustration
5 точек расширения SpringBoot, супер практично!
boy illustration
Глубокое понимание сопоставления индексов Elasticsearch.
boy illustration
15 рекомендуемых платформ разработки с нулевым кодом корпоративного уровня. Всегда найдется та, которая вам понравится.
boy illustration
Аннотация EasyExcel позволяет экспортировать с сохранением двух десятичных знаков.