Вы используете мобильную версию

перейти на Полную версию сайта

Запись

[Pytex] Параллелизм на продакшен примерах. Тариф Стандарт (Артем Шумейко)

Складчина [Pytex] Параллелизм на продакшен примерах. Тариф Стандарт (Артем Шумейко). Совместные покупки курсов, тренингов, обучения. Присоединяйтесь! Важен каждый вкладчик.

Тема найдена по тегам:
Цена:
39000 руб
Взнос:
816 руб
Организатор:
Евражкa

Список участников складчины:

1. Евражкa
open
2
Записаться
  1. Евражкa
    Евражкa Организатор складчин

    [Pytex] Параллелизм на продакшен примерах. Тариф Стандарт (Артем Шумейко)

    [​IMG]


    Этот курс — твоя ступенька к росту.
    Если ты научишься применять конкурентность и параллелизм в продакшен проектах, ты сможешь выставлять это, как одно из самых сильных качеств при повышении грейда.

    Скорее всего ты уже
пытался изучить эти темы:


    Асинхронность, потоки и процессы, смотрел статьи
и видео — но так и не понял, как это применять в реальной разработке
    • Учебные примеры
не похожи на работу
    • Непонятно, какой инструмент выбрать под задачу
    • Знания есть, но цельной картины нет
    Тебе нужно знать:
    • FastAPI
    • PostgreSQL
    • Docker
    • Git
    Основная ценность курса —
постоянная практика

    Ты будешь разбирать ошибки в продакшен коде вместе со спикером, и параллельно будешь писать свой проект с использованием новых технологий:
    • Потоки и процессы. Для нетипичной 
IO/CPU нагрузки
    • Высокая нагрузка. Нагрузим 1000 RPS для имитации продакшена
    • Брокеры. Для обработки больших потоков данных из Kafka
    • Websockets. Для трансляции лайв-событий
    • Локальные очереди. Для передачи данных внутри приложения
    • Внешние API. С таймаутами, распределенными rate limiter’ами и локами
    • Распределенные системы. Мьютексы и семафоры для координации распределенных запросов
    Программа:

    Неделя 1. Фундамент конкурентности и параллелизма
    • Разбираем конкурентность и параллелизм по кирпичикам: как задействуются ядра процессора, как переключаются потоки, и как работают сокеты
    • GIL, IO-bound и CPU-bound: что именно блокирует GIL, как он влияет на каждый тип нагрузки и почему CPU-bound задача не ускоряется от async
    • Корутины и событийный цикл изнутри: почему это не просто "тупая" очередь задач, и как его не заблокировать
    • Корутины, потоки, процессы, воркеры: разница, когда что выбрать
    • Tasks и Futures: create_task, получение результата, обработка исключений, отмена и потеря задач
    • gather и TaskGroup: как ведёт себя группа задач при падении одной из них и как безопасно запускать набор задач
    Домашнее задание
    Сравнить последовательный и параллельный запуск корутин, получить блокировку event loop. Поработать с запуском и отменой задач. Вынести блокирующую функцию в поток, CPU-задачу — в процесс.

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

    Неделя 2. Работа с базой данных и внешними API под нагрузкой
    • Знакомство с production-style микросервисом заказов: где в нём прячется конкурентность и что ломается под нагрузкой в первую очередь
    • Как устроены большинство Python библиотек для работы с БД, Redis, брокером, и как не выстрелить себе в ногу при больших нагрузках
    • Параллельные запросы к базе PostgreSQL: что такое thread-safe и coroutine-safe, и почему типичный паттерн Repository ломается в этом случае
    • as_completed и wait: забираем результаты по мере готовности, не дожидаясь самого медленного
    Домашнее задание
    Реализовать HTTP-клиенты к внешним API и параллельно подтягивать данные при создании события. На превью заказа параллельно собирать сущности из БД, не шаря одну сессию. Добавить таймауты, обработку ошибок и retry на временные ошибки.

    Результат недели
    Научишься ходить в базу и внешние API параллельно, переиспользовать TCP-соединения и на реальных примерах увидишь, насколько это ускоряет сервис. Погрузишься в параллельные запросы, которые нужны каждый день, и поймёшь, какой код безопасно выполнять конкурентно.

    Неделя 3. Координация в распределенной системе

    Что меняется, когда сервис живёт запущен в нескольких инстансах? Как согласовать всех воркеров, даже если они живут на разных серверах?

    Паттерн Single Flight: как из тысячи одинаковых запросов пропустить в базу только один (решение проблемы Thundering herd)
    • Распределенная блокировка на примере протухшего токена: продлеваем общий токен внешнего API так, чтобы это сделал ровно один воркер, избежав 429 ошибок
    • Состояние прямо в памяти приложения: когда кэша уже мало и приходится жертвовать оперативкой ради производительности
    Домашнее задание
    Добавить Redis кэш и защитить популярное событие от лавины запросов через паттерн single flight через распределенную блокировку. Решить проблему thundering herd через распределенный мьютекс для обновления протухшего токена. Подтягивать snapshot конфига в память фоновой задачей.

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

    Неделя 4. Фоновые задачи. От простых методов до production-ready
    • TaskIQ и Celery: когда задачу пора отдавать воркеру и чем опасны фоновые задачи
    • Как снизить нагрузку на сервис, используя поллинг для длинных
    • Паттерн Transactional outbox: как не допустить расхождения данных между базой, taskiq/celery и приложением
    • Как ускорить асинхронное приложение через вынос блокирующего кода в потоки. Учимся распознавать такой код
    Домашнее задание
    Вынести обработку покупок в Taskiq, отдавая статус для поллинга. Регулярно проверять билет и обновлять статус. Генерировать QR-код синхронным SDK во внешнем потоке.

    Результат недели
    Познакомишься с самыми популярными инструментами для фоновых задач в Python и поймёшь, какие проблемы с ними связаны. Научишься сам выбирать инструмент под задачу: когда выносить CPU-нагрузку, когда I/O и что для этого взять.

    Неделя 5. Очереди, батчинг и потоковая обработка событий из Kafka
    • Зачем использовать очередь asyncio.Queue внутри приложения
    • Батчинг событий в ClickHouse: как снизить нагрузку с базы в сотни раз
    • Как действовать, если не успеваешь обрабатывать входящий поток сообщений из брокера
    • Знакомимся со вторым микросервисом аналитики, с получением тысяч событий из Kafka
    • Как выстроить пайплайн по переливу данных из Kafka в Websocket для рил-тайм слежения за курьерами на карте
    Домашнее задание
    Отправлять аналитику в фоновом режиме, чтобы запрос её не ждал. Копить события в очереди и писать в ClickHouse батчами. Обрабатывать данные из Kafka.

    Результат недели
    Научишься работать с Kafka асинхронно и с вебсокетами, делать батчинг данных и не перегружать базу, что критично важно на продакшене.

    Неделя 6. Профилирование и трейсинг Python приложений
    • Выносим CPU-нагрузку правильно: какие вычисления отпускают GIL и почему от этого зависит выбор между потоками и процессами
    • Тяжёлый отчёт уезжает в воркер: клиент опрашивает статус и забирает готовый файл
    • CPU-расчёты по перемещениям курьеров и генерация Excel — в ProcessPoolExecutor, чтобы сервис не замирал
    • Ловим блокировки event loop: лаги, медленные коллбеки и охота за тем, что подвешивает сервис
    • Трейсинг сквозного запроса через contextvars: видим весь путь запроса, даже когда всё перемешано в логах
    • Graceful shutdown: гасим сервис с фоновыми задачами, очередями и воркерами без потери данных
    Домашнее задание
    Реализовать запуск отчёта о продажах через Taskiq с поллингом и скачиванием файла. Собрать аналитику по продажам и сгенерировать Excel отчет, вынеся CPU-вычисление в процесс. Добавить мониторинг блокировок event loop и трейсинг.

    Результат недели
    Разберёшься, как правильно выносить CPU-нагрузку, и научишься профилировать и трейсить асинхронный код, находя узкие места под нагрузкой.

    Тариф Стандарт
    • будут доступны все материалы курса
    • доступ к еженедельным встречам без проверки заданий

     
    Евражкa, 25 июн 2026 в 13:46
  2. Похожие складчины
    Загрузка...
Наверх