О чём курс
Программа «Архитектор ПО. Путь к мастерству в проектировании систем» разбита на 8 курсов, объединенных сквозным кейс-проектом «Микросервисная архитектура food-tech приложения с алгоритмическим движком», который позволяет увидеть процесс работы архитектора целиком, прожить каждый этап на практике, сохранив себе образец выполнения задачи.
Помимо реализации кейс-проекта, в рамках курсов предусмотрено выполнение промежуточных заданий для закрепления теории.
Обучение проходит в смешанном формате:
-
Изучаете материалы курсов в системе дистанционного обучения (СДО). По окончании теоретической части каждого курса программы проходите тест для проверки уровня знаний.
-
Посещаете практические сессии с преподавателем, на которых дополнительно разбирается каждый этап кейс-проекта, обсуждаются вопросы, а также можно познакомиться с опытом и кейсами коллег.
Баланс теории и практики - 40\60, что позволяет сосредоточиться на практических аспектах и сформировать востребованные навыки у выпускников программы.
1. Архитектурные стили программного обеспечения: формирование базовой архитектуры
Курс комплексно обозревает предмет программной архитектуры, знакомит с основными понятиями, ходом мыслей программного архитектора и принципами архитектурного проектирования.
Вы узнаете, как практики DDD служат при проектировании архитектуры. Познакомитесь с основными архитектурными стилями: монолит и микросервисы, узнаете, какие сильные и слабые стороны есть у каждого, на каких основаниях принимается решение о выборе архитектурного стиля. Также, рассмотрите современные варианты применения монолитной архитектуры.
Далее, сделаем обзор альтернативных архитектурных стилей, таких как событийно-управляемая архитектура и архитектура хранилищ данных.
А знакомство с различными видами и позициями архитекторов, поможет спроектировать свой профессиональный путь развития.
2. Работа с требованиями при проектировании архитектуры
Узнаете о связи заинтересованных сторон, целей, требований и архитектуры в программной разработке.
Будут рассмотрены понятия функциональных и нефункциональных требований, выделены движущие силы архитектуры, определено, почему нефункциональные требования важны и как они, во многом, определяют дальнейший вид программного продукта.
Будут предложены методы формулирования функциональных и нефункциональных требований, каталоги и чек-листы нефунциональных требований. Рассмотрена связь требований и бизнес-целей, объяснена первичность и приоритетность бизнес-целей, предложена классификация бизнес-целей, призванная облегчить понимание темы техническими специалистами.
Далее, рассмотрим подходы выявления нефункциональных требований при ограниченной детализации контекста. Будут предложены методики формирования соглашений об уровне обслуживания, принципы формирования SLA. User Stories.
3. Создание устойчивых решений: принципы проектирования
В этом курсе мы будем говорить о логике и последовательности шагов при проектировании архитектуры. Рассмотрим методику проектирования, направленную на достижение атрибутов качества.
От общего к частному будут рассмотрены тактики и паттерны, направленные на достижение целевых показателей по Надежности, Производительности, Безопасности, Модифицируемости. Дополнительно будут рассмотрены лучшие практики безопасности веб-приложений.
4. Технологии интеграции и взаимодействия микросервисов
В этом курсе мы подтвердим факт того, что интеграция приложений была и остается важнейшим аспектом архитектурного проектирования, распространяясь от мира интеграции корпоративных приложений до связи микросервисов между собой.
Будут рассмотрены основные способы интеграции приложений через: Файлы, Базы данных, Удаленный вызов, Брокер, выделены сильные и слабы стороны каждого из них. Подробно рассмотрим Синхронное и Асинхронное взаимодействие. Будет произведен обзор шаблонов интеграции приложений, среди них: Очередь, Публикация-Подписка, Маршрутизация, Конечная точка, Каналы и Фильтры, принципы построения сообщений.
Изучим практические технологии интеграции: REST, gRPC, RabbitMQ, Kafka а так же технологии документирования API: Open API Spec, Async API Spec.
Дополнительно будет предложена классификация нефункциональных требований к интеграции и предоставлен шаблон описания интеграционного потока и сервиса API.
5. Технологии хранения и управления информацией
Вы познакомитесь с задачами хранения информации, подробно рассмотрите принципы проектирования реляционных баз данных. Научитесь проектировать модели данных и документировать их в виде ER диаграммы, познакомитесь с разными типами связей на примере бизнес-сущностей типа клиенты/счета/карты. Будут рассмотрены понятия нормализации, денормализации, как возможности характеристики производительности. Так же будут рассматриваться способы оптимизации производительности, такие как индексы, материализованные представления, копии на чтение.
Рассмотрим механизмы организации конкурентного доступа к информации в реляционных базах данных, продвинутые темы, такие как партиционирование и шардирование.
В курсе будет произведен обзор видов нереляционных баз данных, изложены варианты и типовые случаи их использования, рассмотрена методика выбора базы данных.
6. Системная архитектура: дизайн и оптимизация инфраструктуры
На этом курсе вы научитесь определять, как принципы развертывания приложений оказывают влияние на атрибуты качества. Сможете ставить задачи и проверять результаты работы системных инженеров, администраторов и специалистов DevOps.
Мы рассмотрим основы принципов построения сетей, архитектуры Linux, построения CI/CD Pipeline, мониторингов приложения. Познакомимся с облачными архитектурами, узнаем о возможностях и экономике облачных решений. Будут рассмотрены основные аспекты архитектуры и практического использования Kubernetes.
Дополнительно предлагается обзор практик SRE (Site Reliability Engeneer) для организации надежного отказоустойчивого решения, как с точки зрения архитектуры, так и с точки зрения практик эксплуатации.
7. Документирование архитектурных решений: BPMN, UML, нотация 4+1 и ADR
После прохождения курса вы сможете анализировать диаграммы BPMN, самостоятельно разрабатывать диаграммы C4, UML, относящиеся к архитектуре. Рассмотрим нотации 4+1, позволяющие с разных точек зрения взглянуть на архитектуру. Вы научитесь подбирать подходящие диаграммы и использовать их для коммуникации с заинтересованными сторонами в разных контекстах.
Подход ADR (Architecture Decision Records) позволит вам познакомиться с современными способами документирования эволюционной архитектуры.
8. Soft Skills
Мы не забудем и о развитии навыков управления временем, организации коммуникаций и делегирования. Вы узнаете, как принципы личной эффективности помогут высвободить время для важных архитектурных задач.
Вы сможете объединить все полученные знания и опыт в профессиональную презентацию и успешно защитить ее перед заказчиком.
Предварительная подготовка
- уметь читать код;
- знать основы разработки: ООП;
- знать,как устроен процесс разработки ПО;
Для кого
Состав программы
Архитектурные стили программного обеспечения: формирование базовой архитектуры
Работа с требованиями при проектировании архитектуры
Создание устойчивых решений: принципы проектирования
Технологии интеграции и взаимодействие микросервисов
Технологии хранения и управления информацией
Системная архитектура: дизайн и оптимизация инфраструктуры
Документирование архитектурных решений: BPMN, UML, нотация 4+1 и ADR
132 000 ₽
118 800 ₽ — для физ. лиц