• TopKursy - РЕДКИЕ Удаленные КУРСЫ!

    Эксклюзивные материалы, недоступные на других источниках.

    Откройте доступ к уникальным знаниям прямо сейчас!

    Подробнее

Скоро! Микросервисы, как в BigTech [Тариф «Без проверки»] [Олег Козырев] [Повтор]

  • Автор темы EGround
  • Дата начала
Статус
В этой теме нельзя размещать новые ответы.
EGround

EGround

Редактор
Сообщения
24.317
Реакции
127

Микросервисы, как в BigTech [Тариф "Без проверки"] [Олег Козырев] [Повтор]​


 имени.png


Научись разрабатывать высокопроизводительные, масштабируемые микросервисы, как в ВК Yandex OZON Avito СБЕР Тинькофф, и увеличь свои шансы на трудоустройство в BigTech или повышения грейда

Обучение подойдет для Junior и Middle backend-разработчиков

Для курса нужно:

  • Знать основы Golang — все практические примеры будут на нем
  • Уметь пользоваться git, чтобы качественно работать с кодовой базой

Курс адаптирован под частые проблемы backend-a, с которыми приходится сталкиваться на работе
На обучении ты глубоко погрузишься в микросервисы
Беспощадно кодим микросервисы на протяжении 8 недель


Спойлер: Программа Неделя 1. Знакомство, протоколы http и gRPC

  • Что такое протокол http
  • Напишем http-сервер
  • Что такое REST
  • Чем плох json
  • Что такое protobuf
  • Чем плох http 1.1
  • Что такое gRPC?
  • Пишем первый proto-файл
  • Генерируем proto-файл
  • Реализуем простую логику ручек
  • Поднимем gRPC-сервер со своим API
  • Реализуем gRPC-клиент

Результат: создашь два рабочих микросервиса с gRPC-серверами внутри, которые поддерживают базовый API

Неделя 2. Deploy сервиса в облако и работа с PostgreSQL


  • Регистрируемся в Selectel и покупаем свой сервер
  • Собираем приложение и запускаем его на сервере
  • Что такое Docker
  • Разберемся, в чём суть контейнеризации, какая разница между ней и виртуализацией
  • Пишем Docker файл для приложения и собираем его
  • Создаем registry для docker образов в Selectel и загружаем наш образ
  • Устанавливаем docker на наш сервер
  • Запускаем приложение из нашего образа
  • Что такое GitHub Actions
  • Пишем actions для деплоя и запуска нашего приложения
  • Что такое config и почему их бывает несколько
  • Пишем config’и для разных сред
  • Пишем обработчик config’а
  • Что такое Postgres
  • Запуск Postgres в Docker Compose
  • Что такое миграции
  • Пишем миграции и накатываем их с помощью утилиты goose
  • Простые запросы в Postgres с помощью pgx
  • Пишем запросы с помощью билдера squirrel
  • Заворачиваем накатку миграций в отдельный Docker контейнер

Результат: Разработаешь базовую бизнес-логику созданных ранее API с использованием базы данных PostgreSQL

Неделя3. Архитектура проекта


  • Что такое слои и зачем они нужны
  • Пишем repo-слой
  • Пишем сервисный слой
  • Пишем модели и конверторы
  • Пишем инициализацию всех зависимостей
  • Что такое DI контейнер
  • Пишем свой DI контейнер
  • Недостаток работы с pgx напрямую
  • Пишем свою обертку над клиентом к БД
  • Что такое транзакции
  • Недостаток работы с транзакциями через pgx
  • Пишем свой transaction manager
  • Встраиваем transaction manager в свою обертку над клиентом к БД

Результат: научишься рефакторингу и сделаешь удобную, расширяемую и гибкую

Неделя 4. Тестирование сервиса и создание своей платформенной библиотеки


  • Зачем нужны тесты
  • Какие виды тестов бывают
  • Пишем юнит-тесты для простого кода
  • Пишем юнит-тесты для кода с моками зависимостей
  • Что такое платформенная библиотека
  • Создаем свою платформенную библиотеку

Результат: покроешь функционал своих сервисов unit-тестами и создашь собственную платформенную библиотеку, состоящую из общих компонентов твоих проектов

Неделя 5. Дополнительные опции экосистемы gRPC

  • В чем проблема gRPC
  • Что такое grpc-gateway
  • Описываем опции gateway в proto-файле
  • Генерируем proto-файл с gateway
  • Поднимаем http-сервер для работы с gateway
  • Что такое proto-валидация
  • Описываем опции валидации в proto-файле
  • Генерируем proto-файл с валидацией
  • Применяем сгенерированную валидацию
  • Что такое интерцептор?
  • Пишем валидационный интерцептор
  • Что такое swagger
  • Генерируем proto-файл со swagger и используем результат в Postman
  • Что такое CORS
  • Поднимаем отдельный swagger-сервер

Результат: в одном из сервисов поднимешь свой gRPC-Gateway, который позволит обрабатывать http-трафик

Неделя 6. Безопасность сетевых взаимодействий между серверами

  • Что такое TLS
  • Генерируем сертификаты
  • Подключаем сертификаты на сервере
  • Подключаем сертификаты на клиенте
  • Что такое JWT
  • Описываем контракты аутентификационного API
  • Пишем генерацию access токена
  • Пишем генерацию refresh токена
  • Пишем проверку валидности токена
  • Учимся передавать и принимать токен через контекст
  • Пишем серверный и клиентский интерцепторы для работы с токеном

Результат

  • Обеспечишь транспортную безопасность взаимодействию твоих сервисов друг с другом
  • Создашь систему аутентификации и авторизации для своих проектов средствами JWT

Неделя 7. Мониторинг системы

  • Что такое логи
  • Zap-логгер
  • Пишем обертку над zap-логгером
  • Что такое метрики
  • Разворачиваем prometheus в Docker-compose
  • Поднимаем сервер для метрик и организуем их сбор
  • Смотрим метрики и интерпретируем их на примере RPS
  • Что такое Grafana
  • Разворачиваем Grafana в Docker-compose
  • Импортируем метрики из prometheus в Grafana
  • Что такое трейсинг
  • Разворачиваем Jaeger в Docker сompose
  • Организуем сбор трейсов

Результат: на примере одного из сервисов добавишь грамотное логгирование о различных событиях, метрики, сигнализурующие о важных показателях системы, а также организуешь сбор трейсов

Неделя 8. Паттерны отказоустойчивости приложения и потоковая обработка данных

  • Что такое timeout
  • Применяем timeout через контекст
  • Что такое Rate Limiter
  • Пишем свой Rate Limiter
  • Что такое Circuit Breaker
  • Подключаем готовую реализацию Curcuit Breaker
  • Система ошибок в gRPC
  • Обсуждаем дизайн системы ошибок для бизнес логики
  • Пишем реализацию валидатора бизнес логики
  • Пишем обработчик ошибок
  • Пишем интерцептор для конвертации бизнес ошибок в транспортные
  • Что такое стриминговые ручки в gRPC
  • Добавляем стриминговую ручку в API
  • Что такое cli-утилита
  • Пишем свою cli-утилиту для связи с сервером

Результат: умеешь применять паттерны отказоустойчивости и работать со стриминговыми ручками в gRPC. Кроме этого, ты разработаешь свою cli-утилиту в качестве чат-клиента
А потом бесплатно учимся хорошо устраиваться в BigTech

Бонус №1 Составишь резюме, после которого приглашают на собеседование.

  • Как на самом деле правильно составлять резюме?
  • Какие главные ошибки айтишников при поиске работы?
  • Красные флаги в резюме, которые не любят рекрутеры

Бонус №2 Научишься при трудоустройстве поднимать оффер на 30 000−70 000 рублей. Максим Фатин. Эксперт по ведению переговоров, Senior Developer

  • Стоит ли говорить рекрутеру ожидания по зарплате?
  • Как тимлид может влиять на твой оффер?
  • Механики и лайфхаки – как поднять финальный оффер?

Бонус №3. Лучшему студенту потока — 3 бесплатные консультации со старшим разработчиком Авито

Спойлер: Преподаватель Олег Козырев, Senior Engineer в Avito Tech. Поболтаем за жизнь, о работе, решим карьерные трудности или глубже разберем темы с курса 1 на 1. А еще можем провести mock-собеседование — погоняю тебя по позиции, на которую хочешь устроиться, и поделюсь фишками прохождения реального собеса

AvitoSenior Engineer
разрабатываю BaaS-платформу (Backoffice as a Service)

Ozon Tech: ЛогистикаSenior Engineer
разрабатывал сервисы организации перевозок товаров продавца на склад

Ozon Tech: МоментыSenior Engineer
разрабатывал систему модерации «рилсов» внутри приложения Ozon

Ozon Tech: МаркетплейсSenior Engineer
разрабатывал сервис, который отслеживает своевременность доставки посылок

Route 256Ex-преподаватель и тьютор
менторил и преподавал курсы по построению микросервисов в школе Ozon Tech

YaTalksВедущий конференции
вел второй день конференции по программированию от Яндекса
Тариф "Без проверки"

  • 18 практических уроков
  • Бессрочная запись курса
  • Домашние задания после лекций
  • Дипломный проект
  • Q&A-сессии и live-разборы домашек
  • Доп.модуль от HR-специалиста
  • Доп.модуль по торгу за зарплату

Цена на данный момент неизвестна, идет предзапись на курс

Повтор складчины


Материал «Микросервисы, как в BigTech [Тариф «Без проверки»] [Олег Козырев] [Повтор]», возможно, скоро появится на EGROUND.
Воспользуйтесь поиском, может быть, он уже опубликован.
 
Статус
В этой теме нельзя размещать новые ответы.
Сверху Снизу