Курс обновлен
Scala-разработчик
Best Practice по Scala, подходам функционального программирования и самым мощным Scala-библиотекам
25 декабря
4 месяца
Онлайн
Пн/Ср 20:00 Мск
Где применяется Scala?
Scala создали на базе Java, но, в отличие своего «родителя», Scala получился лаконичным языком программирования. Языки не взаимоисключают друг друга: если вы пишите на Scala, можете использовать части кода на Java. На Scala разрабатывают микросервисы, инструменты для бизнес-аналитики, машинного обучения, обработки данных, а ещё – социальные сети
Для кого этот курс?
- Для java-разработчиков с опытом от 1 года
- Для разработчиков на других языках с опытом от 3 лет
Необходимые знания
- опыт разработки на Java или других языках
- опыт работы с БД (SQL или NoSQL)
- знакомство с синтаксисом веб-приложений
Будет плюсом
- умение работать с CompletableFuture/Promise
- умение работать с Optional/Maybe
- умение работать с библиотекой коллекций: для Java –Stream API; для C# – LINQ; для Rust – коллекции в Rust; для любого другого языка программирования – понимать, что такое flatMap или аналогичная операция в соответствующем языке
- опыт работы с REST и json
Что вам даст этот курс?
Вы изучите популярные технологии Scala, освоите подходы функционального программирования, а также познакомитесь с мощными библиотеками
Вы научитесь:
- Создавать веб-сервисы с использованием стека технологий Scala
- Использовать приёмы функционального программирования в SOLID-приложениях
- Создавать приложения c помощью библиотеки ZIO, основываясь на функциональном подходе
- Проектировать микросервисы на основе Akka с использованием CQRS/ES
- Создавать модульные тесты на основе инвариантов свойств: property-based tests
Авторская программа
Мы составили программу курса «Scala-разработчик» с учётом требований работодателей. Модули курса помогут вам погрузиться в реальные задачи enterprise-разработки
Процесс обучения
У нас нет предзаписанных уроков.
Занятия в OTUS – это онлайн-вебинары. Преподаватели-практики помогут погрузиться в теорию, обучат на реальных примерах, расскажут о необходимых в работе инструментах. Вы всегда сможете задать вопрос и получить обратную связь.
И самое главное – сможете практиковаться!
Будьте вне конкуренции
Scala постепенно набирает популярность: язык уже внедрили Twitter и Coursera
Учитесь у экспертов
Перенимайте опыт руководителей отделов разработки и старших программистов из крупных компаний
Дополните портфолио
Защитите собственный проект и используйте, как преимущество на собеседовании
Партнеры
- Разместите резюме в базе OTUS: так наши партнёры смогут пригласить вас на интервью
- Участвуйте в карьерных мероприятиях: там мы разбираемся, как составить резюме
Работодатели курса
Формат обучения
Интерактивные вебинары
2 онлайн-занятия по 2 академических часа в неделю, вечный доступ к обучающим материалам
Практика
Итоговая проектная работа усилит знания, а её успешная защита – откроет новые карьерные возможности
Активное комьюнити
Общайтесь с преподавателями на вебинарах, в закрытом телеграм-чате, при проверке домашних заданий
Программа
Cинтаксические конструкции Scala, асинхронность
В данном модуле будут рассмотрены следующие темы: - Введение в Scala - Основные языковые конструкции, синтаксис - Знакомство с функциональными особенностями языка Scala - Библиотека коллекций - Асинхронность силами стандартной библиотеки (Scala Future)
Тема 1: Обзор языковых конструкций. Интерфейсы, классы, методы
Тема 2: Обзор языковых конструкций. Интерфейсы, классы, методы. Часть 2
Тема 3: Функциональные конструкции языка scala
Тема 4: Алгебраические типы данных и сопоставление с образцом
Тема 5: Библиотека коллекций
Тема 6: Библиотека коллекций. Часть 2
Тема 7: Асинхронные операции, обработка исключений, неявные параметры
Тема 8: Асинхронные операции, обработка исключений, неявные параметры. Часть 2
Advanced Scala concepts, знакомство с концепциями функционального программирования
В данном модуле будут рассмотрены следующие темы: - Продвинутые возможности языка Scala - Типы высшего порядка - Scala implicits и type class паттерн - Начинаем знакомство с FP экосистемой Scala на примере библиотеки cats - Рассматрим основные структуры данных и type classes
Тема 1: Higher kind types, implicits, type classes. Часть 1
Тема 2: Higher kind types, implicits, type classes. Часть 2
Тема 3: Scala 3 в сравнении с Scala 2, основные изменения, обзор
Тема 4: Сats core, data types
Тема 5: Cats type classes
Функциональное программирование и эффекты в Scala. Подробное знакомство с ZIO и Cats effect
В данном модуле будут рассмотрены следующие темы: - Функциональное программирование на Scala с «эффектами» - Введем понятие функционального эффекта - Познакомимся с принципами функционального дизайна для некой предметной области - Рассмотрим такие библиотеки, как ZIO и Cats effect.
Тема 1: Введение в функциональные эффекты
Тема 2: ZIO эффект, конструкторы, базовые операции
Тема 3: ZIO модель ошибок
Тема 4: ZIO асинхронность и паралеллизм
Тема 5: ZIO работа с ресурсами
Тема 6: ZIO Environment и его место в DI
Тема 7: ZIO ZLayer, ZIO сервисы, тестирование ZIO программ
Тема 8: ZIO дополнительные типы данных
Тема 9: Cats effects: ведение, основные типы данных
Тема 10: Cats effects: работа с ресурсами
Тема 11: Cats effects: конкурентность
Scala библиотеки fs2 и http4s. Работа с БД
В данном модуле будут рассмотрены следующие темы: - Популярные библиотеки из FP экосистемы Scala - Web + Доступ к БД - Функциональные стримы на примере FS2 - Работа с http с помощью http4s - Реализация взаимодействия с БД JDBC, Scalike, Slick
Тема 1: Функциональные стримы на примере fs2
Тема 2: Введение в http4s + DSL
Тема 3: http4s middleware + аутентификация
Тема 4: http4s стриминг + работа с JSON
Тема 5: Доступ к БД
Akka и CQRS/ES с использованием Akka
В данном модуле будут рассмотрены следующие темы: - Модель акторов и ее реализация на Scala - Библиотека Akka - Событийные архитектуры - Паттерн с разделения команд и запросов (CQRS)
Тема 1: Акка
Тема 2: Обработка потоков данных
Тема 3: Событие как основной тип данных в системе
Тема 4: Разделение команд и запросов
Тема 5: Query часть CQRS
Тема 6: ES в кластере
Проектная работа
Заключительный месяц курса посвящен проектной работе. Свой проект — это то, что интересно писать слушателю. То, что можно создать на основе знаний, полученных на курсе. При этом не обязательно закончить его за месяц. В процессе написания по проекту можно получить консультации преподавателей.
Тема 1: Выбор темы и организация проектной работы
Тема 2: Защита проектных работ
Также вы можете получить полную программу, чтобы убедиться, что обучение вам подходит
Проектная работа
Попробуйте себя в роли разработчика на Scala. Создайте отказоустойчивый, масштабируемый веб-сервис: REST API + backend + базы данных.
Первый этап: классическое SOLID-приложение в пять классов и с хранением данных в памяти.
Второй этап: приложение с FP-подходом (ZIO), расширенной функциональностью, простой схемой в SQL-базе данных.
Третий этап: микросервисы с отказоустойчивостью, ES на основе Akka Persistence, CQRS для сложных запросов
Преподаватели
Алексей Воронец
Naumen
Руководитель разработки департамента проектных решений и поисковых систем
Руководитель разработки департамента проектных решений и поисковых систем в компании Naumen. Опыт профессиональной разработки 14 лет. Последние 9 лет — это Scala. До этого были Java, JavaScript, когда-то знал PHP. Работал в разных странах и в разных командах. География: Беларусь, Франция, Россия Имеет опыт проектной и продуктовой разработки в B2B и B2C сегментах. Участвовал в проектировании, разработке и запуске различных проектов для Минобрнауки, Сколково, Росатома, крупных федеральных вузов. Проектировал, разрабатывал и запускал платформу RUSSIA.STUDY Сфера интересов: Scala, функциональное программирование, архитектура приложений.
Преподает на курсах
- Apache Kafka
- Scala-разработчик
Валентин Шилин
Deutsche Telekom IT GmbH
Старший программист/аналитик данных
Более 15 лет программирования на С++, С#, JavaScript, Python, Scala, Java. Эксперт в обработке больших данных с помощью Scala/Spark и Hadoop Cloudera. Проекты: - автоматизация документооборота для скандинавских стран в составе команды Aditro (10-15 человек); - автоматизация метеорадарной станции (программно-аппаратный комплекс управления метеорадаром MRL5) для активного воздействия на погоду (Болгария- Аргентина) (20 человек); - различные проекты от стартапов до крупных химических предприятий (Eurofins) в Германии с составом команды от 3 до 50 человек. Текущий проект: обработка сверхбольших данных DSL-метрик и прогнозирование потенциальных проблем на линиях связи в Deutsche Telekom. Образование: Прикладная математика и физика, СПбГУ ПM-ПУ Otus Certified Educator
Преподает на курсах
- Python Developer. Professional
- Spark Developer
- Apache Kafka
- Scala-разработчик
Эксперты-практики делятся опытом, разбирают кейсы студентов и дают развернутый фидбэк на домашние задания
Ближайшие мероприятия
Бесплатный открытый вебинар – онлайн-занятие с преподавателем курса. На открытом вебинаре можно посмотреть, как проходит обучение, а ещё – узнать что-то ценное по интересующей теме. На занятии слушатели могут задавать ведущему вопросы
- рассмотрим, что такое стримы и их разновидности;
- изучим конструкторы и комбинаторы fs2;
- проанализируем примеры использования стримов для обработки данных без загрузки в память.
Вебинар будет полезен программистам, аналитикам данных и специалистам по обработке больших данных, которые хотят улучшить свои навыки работы с функциональными стримами и изучить библиотеку fs2.
В результате вебинара вы:
- поймете, что такое стримы и как они отличаются от коллекций;
- как использовать конструкторы и комбинаторы fs2 для обработки данных;
- получите примеры применения стримов в реальных задачах, что позволит оптимизировать обработку данных.
- узнаем, что такое эффекты и какие они бывают;
- познакомимся с понятием функционального эффекта;
- разберемся, какие задачи они могут решать;
- реализуем свой функциональный эффект.
Вебинар подойдет всем разработчикам, знакомым с языком Scala, или рассматривающим этот язык программирования для изучения.
Занятие будет полезно тем, кто не знаком со Scala и только присматривается к переходу на Scala с других языков.
Прошедшие
мероприятия
Корпоративное обучение для ваших сотрудников
- Курсы OTUS верифицированы крупными игроками ИТ-рынка и предлагают инструменты и практики, актуальные на данный момент
- Студенты работают в группах, могут получить консультации не только преподавателей, но и профессионального сообщества
- OTUS проверяет знания студентов перед стартом обучения и после его завершения
- Простой и удобный личный кабинет компании, в котором можно видеть статистику по обучению сотрудников
- Сертификат нашего выпускника за 5 лет стал гарантом качества знаний в обществе
- OTUS создал в IT более 120 курсов по 7 направлениям, линейка которых расширяется по 40-50 курсов в год
Отзывы
Сертификат о прохождении курса
OTUS осуществляет лицензированную образовательную деятельность. В конце обучения вы получите сертификат OTUS о прохождении курса, а при выполнении проектной работы – удостоверение о повышении квалификации
После обучения:
- получите доступ к обучающим материалам: видеозаписям всех вебинаров, презентациям к занятиям, к решениям задач и проектов в виде кода на GitHub
- приобретёте опыт enterprise-разработки на Scala
- дополните портфолио проектом веб-сервиса
Scala-разработчик
Полная стоимость
Стоимость указана для оплаты физическими лицами
вычета до 13% стоимости обучения. Пройдите тестирование и менеджер вас проконсультирует
+7 499 938-92-02 бесплатно