Это курс нашего партнера Партнер
Начало занятий 12 февраля

DevOps практики и инструменты

Общая стоимость: 60000 ₽
В месяц: 15000 ₽
4 часа в неделю
5 месяцев
О курсе

DevOps решает задачу взаимодействия инженеров между собой с целью помочь им быстрее создавать и обновлять сервисы и приложения. На курсе будут разобраны инструменты для реализации практик инфраструктура как код, непрерывная поставка ПО и непрерывный сбор метрик (мониторинг и логирование).
Курс составлен на основе опыта, накопленного компанией Экспресс 42, которая на протяжении уже более 5 лет, помогает внедрять DevOps практики в крупных российских и зарубежных компаниях. Все занятия проводятся действующими инженерами компании.
Необходимое время: 2 лекции в неделю по 2 академических часа и 4 часа на домашнее задание.
Практические задания будут выполняться с использованием Google Cloud Platform (GCP). Для того чтобы сделать использование ресурсов GCP бесплатным для участников курса, от вас потребуется наличие Google аккаунта, у которого не активирован бесплатный пробный период (free trial) в GCP. Free trial дает $300 на использование GCP в течение года. Для активации free trial будет нужна банковская карта для подтверждения личности. Вдобавок к $300, которые участники получают при использовании free trial, компания Softline предоставит дополнительно каждому участнику $200 на использование GCP. Этих средств хватит для выполнения всех практических заданий в рамках курса.

Программа курса
1
модуль
2
модуль
3
модуль
4
модуль
5
модуль
DevOps. Необходимость меняться
Занятие 1: Что такое DevOps и история его развития.
Как DevOps меняет жизнь и работу компаний. DevOps как профессия. Обзор курса.
Занятие 2: DevOps как система.
Практики и методики. DevOps компетенции.
Занятие 3: Система контроля версий как основа разработки и поставки ПО. Знакомство с Git.

ДЗ

Работа с локальным и удаленным репозиториями, исправление комитов, решение конфликтов, работа с ветками и практика Code Review..
Занятие 4: Локальное окружение инженера. ChatOps и визуализация рабочих процессов.

ДЗ

Настройка локального окружения и практика ChatOps..
Занятие 5: Знакомство с облачной инфраструктурой и облачными сервисами.
Практики безопасного доступа к ресурсам (SSH, Bastion Host, VPN).

ДЗ

Запуск VM в GCP, управление правилами фаервола, настройка SSH подключения, настройка SSH подключения через Bastion Host, настройка VPN сервера и VPN-подключения..
Занятие 6: Основные сервисы Google Cloud Platform (GCP).
Способы управления ресурсами в GCP.

ДЗ

Практика управления ресурсами GCP через gcloud.. Ручной деплой тестового приложения. Написание bash скриптов для автоматизации задач настройки VM и деплоя приложения.
Управление инфраструктурой и конфигурацией
Занятие 7: Модели управления инфраструктурой.
Работа с образами VM в облаке. Знакомство с Packer и экосистемой компании HashiCorp.

ДЗ

Подготовка базового образа VM при помощи Packer.. Деплой приложения с использованием подготовленного базового образа.
Занятие 8: Практика Infrastructure as a Code (IaC).
Знакомство с Terraform.

ДЗ

Декларативное описание в виде кода инфраструктуры GCP, требуемой для запуска тестового приложения, при помощи Terraform..
Занятие 9: Принципы организации инфраструктурного кода и работа над инфраструктурой в команде на примере Terraform.

ДЗ

Создание Terraform модулей для управления компонентами инфраструктуры.. Описание и настройка инфраструктуры нескольких окружений. Работа с Terraform remote backend.
Занятие 10: Управление конфигурацией.
Основные DevOps инструменты: Chef, Ansible, Puppet, Salt. Знакомство с Ansible.

ДЗ

Написание Ansible плейбуков на основе имеющихся bash скриптов.. Сборка базовых образов при помощи Packer и Ansible.
Занятие 11: Продолжение знакомства с Ansible: templates, handlers, dynamic inventory, vault, tags.

ДЗ

Управление настройками хостов и деплой приложения при помощи Ansible..
Занятие 12: Принципы организации кода для управления конфигурацией.
Ansible роли, управление настройками нескольких окружений и best practices.

ДЗ

Написание Ansible ролей для управления конфигурацией сервисов и настройками хостов.. Организация репозитория для работы с несколькими окружениями. Работа с Ansible Galaxy и комьюнити ролями.
Занятие 13: Локальная разработка Ansible ролей с Vagrant. Тестирование конфигурации.

ДЗ

Доработка имеющихся ролей локально с использование Vagrant.. Тестирование конфигурации при помощи Molecule и TestInfra.
Continuous Integration & Continuous Delivery с использованием Docker
Занятие 14: Технология контейнеризации. Введение в Docker.

ДЗ

Установка Docker, запуск контейнера на локальной машине, выполнение команд внутри контейнера, создание образа контейнера на основе запущенного..
Занятие 15: Docker контейнеры. Docker под капотом

ДЗ

Запуск VM с установленным Docker Engine при помощи Docker Machine. Написание Dockerfile и сборка образа с тестовым приложением. Сохранение образа на DockerHub..
Занятие 16: Docker образы. Микросервисы

ДЗ

Разбиение приложения на несколько микросервисов. Выбор базового образа. Подключение volume к контейнеру..
Занятие 17: Сетевое взаимодействие Docker контейнеров. Docker Compose. Тестирование образов

ДЗ

Практика работы с основными типами Docker сетей. Декларативное описание Docker инфраструктуры при помощи Docker Compose..
Занятие 18: Технология непрерывной поставки ПО

ДЗ

Чтение литературы.
Занятие 19: Устройство Gitlab CI. Построение процесса непрерывной интеграции

ДЗ

Gitlab CI. Построение процесса непрерывной интеграции.
Занятие 20: Непрерывная поставка с Gitlab CI

ДЗ

Расширяем существующий CI пайплайн. Работа с окружениями в Gitlab CI для построения непрерывной поставки функционала приложений..
Fast Feedback Loop (мониторинг и логирование)
Занятие 21: Введение в мониторинг. Модели и принципы работы систем мониторинга

ДЗ

Создание и запуск системы мониторинга Prometheus.. Мониторинг состояния микросервисов, сбор метрик при помощи prometheus exporters.
Занятие 22: Мониторинг приложения и инфраструктуры
Занятие 23: Визуализация и анализ результатов мониторинга. Знакомство с системами рассылки оповещений, Алертинг

ДЗ

Сбор и анализ метрик приложений, а также бизнес метрик. Создание уведомлений на основе собранных данных..
Занятие 24: Применение инструментов для обработки лог данных
Что такое логи и зачем они нужны? Системы централизованного хранения лог данных, требования к ним и примеры. Форматы и варианты логирования приложений

ДЗ

Логирование приложений.. Структурированные и неструктурированные логи. Организация централизованной системы логирования.
Занятие 25: Применение системы логирования в инфраструктуре на основе Docker.
Рассмотрение систем распределенной отладки данных (Distributed tracing)

ДЗ

Логирование приложений.. Структурированные и неструктурированные логи. Продолжение создания и работы централизованной системой логирования.
Контейнерная Оркестрация
Занятие 26: Контейнерная оркестрация.
Примеры известных и актуальных систем оркестрации (DC/OS, Aurora, Nomad, Docker Swarm)
Занятие 27: Детальное знакомство с Docker Swarm.
Работа сети в кластере, политики учета и деплоя приложений в Swarm mode.

ДЗ

Создание кластера на основе Docker Swarm. Конфигурация приложения для работы в Swarm mode.
Занятие 28: Введение в Kubernetes.
Основные концепции и архитектура системы.

ДЗ

Установка и настройка Kubernetes.. Работа над автоматизацией процесса развертывания системы.
Занятие 29: Основные модели безопасности и контроллеры в Kubernetes

ДЗ

Установка и настройка Google Kubernetes Engine, настройка локального профиля администратора для GKE. Работа с с контроллерами: StatefulSet, Deployment, DaemonSet.
Занятие 30: Ingress-контроллеры и сервисы в Kubernetes.
Работа с удаленными хранилищами данных.
Занятие 31: Интеграция Kubernetes в GitlabCI.
Использование формата упаковки приложений Charts в Kubernetes Helm.
Занятие 32: Масштабирование в Kubernetes
Расписание
Дата и время
Событие
Группа
DevOps практики и инстр.-2017-11
23 января, вторник
20:00 — 21:30
Технология контейнеризации. Введение в Docker.
DevOps практики и инстр.-2017-11
DevOps практики и инстр.-2017-11
26 января, пятница
20:00 — 21:30
Docker контейнеры. Docker под капотом
DevOps практики и инстр.-2017-11
DevOps практики и инстр.-2017-11
30 января, вторник
20:00 — 21:30
Docker образы. Микросервисы
DevOps практики и инстр.-2017-11
DevOps практики и инстр.-2017-11
2 февраля, пятница
20:00 — 21:30
Сетевое взаимодействие Docker контейнеров. Docker Compose. Тестирование образов
DevOps практики и инстр.-2017-11
Преподаватели
Александр Титов
Александр Титов Развивает тему DevOps в России, внедряет системы управления конфигурацией, занимался эксплуатацией интернет-проектов в компаниях Скалакси, Skype, Qik, Microsoft.
Артем Старостенко
Специализуруется на управлении облачной инфраструктурой, конфигурацией и использовании систем оркестрации. Влюблен в Docker с первого дня своего знакомства и считает, что технология контейнеризации основа не только будущего, но уже настоящего современного процесса разработки и поставки цифрового продукта.
Сергей Богатырец
Помогает внедрять практики непрерывной поставки, улучшать процессы управления инфраструктурой и ее мониторинга. За время работы в Экспресс42 работал над проектами Рокетбанк, Paymantix, Cloudlock и Первый ОФД.
Юрий Игнатов
В должности старшего инженера в компании Express42 Юрий разрабатывает и внедряет решения для непрерывной поставки продуктов enterprise-организаций, помогает с адаптацией DevOps-практик, а так же проводит обучения и мастер-классы по дисциплинам автоматизации и управлению конфигурацией.
Виталий Хабаров
Работая системным администратором, пришёл к выводу, что полезные задачи надо автоматизировать, а от деятельности, не приносящей пользу, следует избавляться. Устроившись в компанию Экспресс 42, открыл для себя практики DevOps, которые сейчас и помогает распространять внутри компаний-разработчиков.
Работодатели