- #1
Голосов: 0
0.0
5
0
0
https://tor5.pirat.bz/threads/balun-courses-%D0%9C%D0%B8%D0%BA%D1%80%D0%BE%D1%81%D0%B5%D1%80%D0%B2%D0%B8%D1%81%D1%8B-%D0%BA%D0%B0%D0%BA-%D0%B2-bigtech-%D0%BA%D0%BE%D0%BC%D0%BF%D0%B0%D0%BD%D0%B8%D1%8F%D1%85-2023.247415/
Автор: Balun.Courses
Название: Микросервисы, как в Bigtech-компаниях (2023)
Описание:
НА КУРСЕ ТЫ ГЛУБОКО ПОГРУЗИШЬСЯ В МИКРОСЕРВИСЫ:
Скачать:
Название: Микросервисы, как в Bigtech-компаниях (2023)
Описание:
НА КУРСЕ ТЫ ГЛУБОКО ПОГРУЗИШЬСЯ В МИКРОСЕРВИСЫ:
- Освоишь базовое использование протокола http в Golang-приложениях
- На практике научишься применять архитектурные подходы построения сервисов
- Освоишь работу с PostgreSQL, написав свои компоненты-заготовки, упрощающие дальнейшую разработку
- Поработаешь с кешированием данных на примере Redis и освоишь паттерны отказоустойчивости микросервисов
- Обеспечишь мониторинг своего сервиса и покроешь его тестами, чтобы точно исключить ошибки в работе
- Реализуешь межсервисное взаимодействие, систему аутентификации и авториизации
- Изучишь необходимый стек для разработки микросервисов и сможешь откликаться на классные вакансии: Go, http, gRPC, Redis, Postgres, Prometheus и др.
- Узнаешь лучшие практики построения микросервисов для уверенной работы в BigTech-компании
- Научишься писать сложные проекты с масштабируемым кодом, как это делают разработчики в ведущих IT-компаниях
- Сможешь разработать собственный проект с использованием своих платформенных библиотек
Подробнее:Программа курса
Неделя 1.
Знакомство, протокол http и gRPC
Результат: создашь два рабочих микросервиса с gRPC-серверами внутри, которые поддерживают базовый API.
- Что такое протокол http
- Напишем http-сервер
- Что такое REST
- Чем плох json
- Что такое protobuf
- Чем плох http 1.1
- Что такое gRPC?
- Пишем первый proto-файл
- Генерируем proto-файл
- Реализуем простую логику ручек
- Поднимем gRPC-сервер со своим API
- Реализуем gRPC-клиент
Неделя 2
Deploy сервиса в облако и работа с PostgreSQL
Результат: разработаешь базовую бизнес-логику созданных ранее API с использованием базы данных PostgreSQL.
- Регистрируемся в Selectel и покупаем свой сервер
- Собираем приложение и запускаем его на сервере
- Что такое Docker
- Разберемся, в чём суть контейнеризации, какая разница между ней и виртуализацией, а также познакомимся с Kubernetes
- Пишем Docker файл для приложения и собираем его
- Создаем registry для docker образов в Selectel и загружаем наш образ
- Устанавливаем docker на наш сервер
- Запускаем приложение из нашего образа
- Что такое GitHub Actions
- Пишем actions для деплоя и запуска нашего приложения
- Что такое config и почему их бывает несколько
- Пишем config’и для разных сред
- Пишем обработчик config’а
- Что такое Postgres
- Запуск Postgres в Docker Compose
- Что такое миграции
- Пишем миграции и накатываем их с помощью утилиты goose
- Простые запросы в Postgres с помощью pgx
- Пишем запросы с помощью билдера squirrel
- Заворачиваем накатку миграций в отдельный Docker контейнер
Неделя 3
Архитектура проекта
Результат: научишься рефакторингу и сделаешь удобную, расширяемую и гибкую архитектуру своих проектов.
- Что такое слои и зачем они нужны
- Пишем repo-слой
- Пишем сервисный слой
- Пишем модели и конверторы
- Пишем инициализацию всех зависимостей
- Что такое DI контейнер
- Пишем свой DI контейнер
- Недостаток работы с pgx напрямую
- Пишем свою обертку над клиентом к БД
- Что такое транзакции
- Недостаток работы с транзакциями через pgx
- Пишем свой transaction manager
- Встраиваем transaction manager в свою обертку над клиентом к БД
Неделя 4
Тестирование сервиса и создание платформенной библиотеки
Результат: покроешь функционал своих сервисов unit-тестами и создашь собственную платформенную библиотеку, состоящую из общих компонентов твоих проектов.
- Зачем нужны тесты
- Какие виды тестов бывают
- Пишем юнит-тесты для простого кода
- Пишем юнит-тесты для кода с моками зависимостей
- Что такое платформенная библиотека
- Создаем свою платформенную
Неделя 5
Дополнительные опции экосистемы gRPC
Результат: в одном из сервисов поднимешь свой gRPC-Gateway, который позволит обрабатывать http-трафик. Опишешь proto-валидацию и автоматически сгенерируешь интерактивную документацию API Swagger.
- В чем проблема gRPC
- Что такое grpc-gateway
- Описываем опции gateway в proto-файле
- Генерируем proto-файл с gateway
- Поднимаем http-сервер для работы с gateway
- Что такое proto-валидация
- Описываем опции валидации в proto-файле
- Генерируем proto-файл с валидацией
- Применяем сгенерированную валидацию
- Что такое интерцептор?
- Пишем валидационный интерцептор
- Что такое swagger
- Генерируем proto-файл со swagger и используем результат в Postman
- Что такое CORS
- Поднимаем отдельный swagger-сервер
Неделя 6
Безопасность сетевых взаимодействий между сервисами
Результат: обеспечишь транспортную безопасность взаимодействию твоих сервисов друг с другом. Создашь систему аутентификации и авторизации для своих проектов средствами JWT.
- Что такое TLS
- Генерируем сертификаты
- Подключаем сертификаты на сервере
- Подключаем сертификаты на клиенте
- Что такое JWT
- Описываем контракты аутентификационного API
- Пишем генерацию access токена
- Пишем генерацию refresh токена
- Пишем проверку валидности токена
- Учимся передавать и принимать токен через контекст
- Пишем серверный и клиентский интерцепторы для работы с токеном
Неделя 7
Мониторинг системы
Результат: на примере одного из сервисов добавишь грамотное логгирование о различных событиях, метрики, сигнализурующие о важных показателях системы, а также организуешь сбор трейсов.
- Что такое логи
- Zap-логгер
- Пишем обертку над zap-логгером
- Что такое метрики
- Разворачиваем prometheus в Docker-compose
- Поднимаем сервер для метрик и организуем их сбор
- Смотрим метрики и интерпретируем их на примере RPS
- Что такое Grafana
- Разворачиваем Grafana в Docker-compose
- Импортируем метрики из prometheus в Grafana
- Что такое трейсинг
- Разворачиваем Jaeger в Docker сompose
- Организуем сбор трейсов
Неделя 8
Паттерны отказоустойчивости приложения и потокая обработка данных
Результат: умеешь применять паттерны отказоустойчивости и работать со стриминговыми ручками в gRPC. Кроме этого, ты разработаешь свою cli-утилиту в качестве чат-клиента.
- Что такое timeout
- Применяем timeout через контекст
- Что такое Rate Limiter
- Пишем свой Rate Limiter
- Что такое Curcuit Breaker
- Подключаем готовую реализацию Curcuit Breaker
- Система ошибок в gRPC
- Обсуждаем дизайн системы ошибок для бизнес логики
- Пишем реализацию валидатора бизнес логики
- Пишем обработчик ошибок
- Пишем интерцептор для конвертации бизнес ошибок в транспортные
- Что такое стриминговые ручки в gRPC
- Добавляем стриминговую ручку в API
- Что такое cli утилита
- Пишем свою cli утилиту для связи с сервером
Для просмотра ссылок пройдите регистрацию
Скачать:
Для просмотра ссылок пройдите регистрацию
Вложения
-
182.3 КБ Просмотры: 0