Проектирование программных систем 2024

Материал из Public ATP Wiki
Версия от 12:39, 21 августа 2024; Zueva.mipt (обсуждение | вклад) (Учебный проект)
Перейти к: навигация, поиск

Общие сведения

Общая информация

На курсе вы узнаете как использовать язык моделирования UML2 в разработке распределенных приложений в микросервисной архитектуре (MSA) с применением метода предметно-ориентированного проектирования (Domain-Driven Design).

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

Практика предполагает выполнение и защиту двух заданий по командному курсовому проекту.

Для разработчиков, системных аналитиков и будущих архитекторов программного обеспечения.

Руководитель курса

Хританков Антон

Примерный план

Неделя Раздел Тема
07/09 INTRO+REQ Введение в курс (качество ПО, цели курса). Кратко о требованиях. Сценарии. Фичи. Варианты использования (динамич. представл.)
15/09 REQ Потоки данных DFD. Разработка требований к продуктам. Элементы customer development. Персоны. Метод JTBD. Путешествия. Истории пользователей и истории задач. Процесс разработки требований.
22/09 DDD+UML2 Объектно-ориентированное моделирование. Системы типов. Абстрактные типы данных (ADT). Понятие о классах. Статическое представление модели UML2. Сравнение с моделями данных ER
29/09 DDD Выделение классов и построение моделей в Методы именных групп и Аббота, контрольные списки. Переход к статической модели UML. Повсеместный язык, сущности, агрегаты. Окрестности, предметные области.
06/10 DDD+UML2 Моделирование поведения. Согласованность моделей. Проектирование на основе обязанностей (метод CRC, RDD).
13/10 UML2 Динамическое представление модели (кооперации, последовательности). Статическое представление модели (структурные классы, расширенные классы, пакеты)
20/10 UML2 Динамическое представление модели. Схемы состояний. Представление деятельности. Action Language
27/10 UML2+PROC Построение согласованных моделей. Big Picture UML2. Процесс гибкого моделирования по требованиям (на основе ICONIX+AM+DDD)
02/11 ARCH Методы структурного проектирования (история, связность и сцепление, постепенное уточнение). Введение в архитектуру ПО (определение,стили).
09/11 ARCH+UML2 Функциональная декомпозиция. UML 2. Диаграммы компонентов и размещения
16/11 MSA Введение в микросервисную архитектуру. Ресурсы. Распределенные системы. Декомпозиция на окрестности и на сервисы. Гексагональная архитектура. Паттерны API и коммуникаций. Представление на диаграмме компонентов.
23/11 MSA Паттерны, принципы SOLID в реализации микросервисов. Фреймворки.
30/11 MSA Объектно-ориентированное проектирование. Применение паттернов проектирования.
07/12 MSA+DATA Проектирование данных. Реляционная, размерностные, нереляционные модели. Применение для MSA
14/12 ARCH+MSA Измерения в проектировании. Метрики сложности программ, оценка качества дизайна для ООП, для MSA
21/12 EXAM Защита проектов по курсу

Учебный проект

Учебный проект - это ваш полигон, где вы практикуетесь в применении DDD к разработке микросервисных приложений. По проекту будет два задания, объединенные общей темой. Это может быть упрощенный аналог существующей системы, или ваш собственный проект, или часть дипломной работы.

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

Примерная таблица этапов проекта и применяемых методов проектирования.

# Этап Методы и результаты Задачи
1 Анализ требований к продукту Customer Development, JTBD, JTBD Interview, Personas, User story, Job story, Story Map, Customer Journey Map*, Value Proposition Canvas*, Jobs Map*, UI Wireframes, Product features Предложить и описать образ продукта и решаемые задачи. Определить аудиторию и провести интервью с пользователями. Сформулировать полезные функции и ограничить его рамки. Прояснить элементарные сценарии для полезных функций. Составить словарь данных.
2 Разработка модели анализа Use Case model, Use case text, Candidate classes, SIAOUT checklist, Abbot's method/Noun phrases, Entity-Relationship model По описанию продукта разработать модель использования. Выделить кандидаты классов, построить модель предметной области в UML2 или ERD. Выписать важные требования к атрибутам качества по стандарту.
3 Разработка динамической модели Responsibility-driven design, CRC, UML2 Collaborations model and implementation, UML2 Structured classes, UML2 Activity and Statechart and Interactions models, Logical Data-flow model. Разделить сценарии по обязанностям и назначить ролям классов. Разработать модель деятельности или псевдокод для исполняемого поведения, схемы состояний или конечных автоматов для интерактивного и реактивного, модели взаимодействий или потоков данных для эмерджентного поведения. Обновить модель классов / данных.
4 Декомпозиция на микросервисы Data consistency I, Ресурсы и алгоритмы / решетки типов, CRDT, Event storming, Domain-Driven Design, UML2 Components and Deployments models, Physical Data-flow model Разделить модель предметной области на агрегаты и сформировать микросервисы. Разработать модель событий и процессов. Разработать модель компонентов в UML2 или Physical DFD. Разработать модель размещения
5 Техническое проектирование Microservices applications, Reference architecture, Technology stacks, RESTful API, HTTP(S)/URL/HATEOAS, API Design patterns Выбрать и обосновать эталонную архитектуру для приложения. Подобрать библиотеки и каркасы, инструменты разработки, сравнить и обосновать выбор. Разработать API сервисов применив RESTful API и паттерны проектирования API. Представить в виде OpenAPIv3 схемы.
6 Проектирование данных и прототип Polyglot persistence, Relational schema, NoSQL, Data consistency II: Saga and CRDT and 2PC, Develop prototype with source code, SOLID and GoF patterns, MSA Metrics Перейти от логической модели к физической схеме хранения данных. Разработать модели процессов взаимодействия микросервисов. Реализовать прототип системы в коде и автоматические интеграционные тесты к нему. Применить и обосновать приципы SOLID или GoF паттерны. Посчитать метрики сложности MSA

Задание 1

Первое задание посвящено проработке требований применению DDD к предметной области, в которой проектируете систему. Прорабатываете и уточняете требования и рамки проекта. В итоге для дальнейшего моделирования с помощью Domain Driven Design нужны 3-4 вариантв использования или 5-6 историй пользователей.

В таблице выше это задание включает этапы 1-3.

Что можно будет освоить:

  • анализ требований: use cases, job/user stories, модели потоков данных, структуры подсистем
  • DDD: анализ повсеместного языка, выделение окрестностей, concept/noun phrase extraction, построение модели предметной области, анализ обязанностей и виды классов: service, entity, aggregate, value object, и т. д.
  • UML2: диаграммы классов, вариантов использования, деятельности или последовательности.

Задание 2

В этом задании нужно декомпозировать систему на сервисы и продумать для них API, переложить на микросервисную архитектуру (MSA), применив архитектурные паттерны для API, работы с реляционными и нереляционными данными, применить паттерны ООП для реализации микросервисов. В результате у вас получится модель реализации (design model) микросервисного приложения, реализующего требования из первого задания. В проекте нужно спроектировать 3-5 связанных микросервисов, совместно решающих задачи первого задания.

В таблице выше это задание включает этапы 4-6.

Что можно будет освоить:

  • DDD: декомпозиция и интеграция окрестностей (bounded context), моделирование сервисов и ресурсов
  • MSA: OpenAPI для RESTful web services, hexagonal architecture, SOLID, GoF паттерны проектирования, Backend-for-Frontend и др.
  • Data: ER диаграммы, схема при чтении, модели данных для NoSQL, в статике, в движении
  • UML2: диаграммы компонентов, расширенные диаграммы классов

Результаты и оценивание проекта

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

Общие критерии оценивания приведены в методичке Критерии оценивания проектов


Задания по проекту, по возможности, выполняются на семинарах, защита проходит в виде доклада, материалы по проекту высылаются на проверку не позднее, чем за 1 неделю до даты доклада.

Если кратко, то оцениваются следующие харатеристики выполненного проекта

  • Согласованность разных представлений в составе проекта между собой
  • Правильность применения методов проектирования
  • Полнота выполнения проекта и следование рекомендациям
  • Обоснованность и целесообразность принятых проектировочных решений
  • Ошибки и недочеты в применении языков моделирования
  • Вклад участников в общий результат
Примеры тем проектов

В таблице примеры тем проектов, предлагавшихся в прошлые годы.

# Название Описание
1 СмартРитейл Интегрируем недоверчивых участников рынка ритейла с помощью блокчейна
2 Ok,Fridge! Холодильник доставит к дивану соки и воды под настроение, дозакажет в магазине
3 ЗалейсяIS Управляем сетью авто-автозаправок, работающих без персонала
4 БезВрача Контролируем соблюдение условий медицинского страхования, и вообще соблюдения правил ЗОЖ
5 Перетачка Едем вместе на чужой машине и везем посылки. Система обеспечивает работу сервиса
6 Как?Никак! Модернизированный CallЦентр, роботы отвечают на типовые вопросы и сами ведут FAQ
7 ДоставимВсе Служба доставки формирует из товаров заказы и перемещает по маршрутам. Маршруты формируются вручную, автоматически как план, динамически. Учет веса и стоимости при планировании
8 Физтех-Такси Агрегатор такси со скидкой на поездки в МФТИ

См. также задачи прошлых лет

Общие сведения

Оценки

Правила оценивания (по баллам, набранным в рамках семестра)

Семинары

Технические ссылки

Сервера