Мелкая питонячая радость #2: Starlette

zpl9o7wewa0yvdjlxlg8kgzwpiu.png


Тунельное зрение

Так уж сложилось, что на Python пишут много веб-приложений. Эту нишу Python разработки почти полностью поделили между собой два здоровых игрока — Django и Flask. Поэтому большой процент программистов, пишущих на Python, заточен на работу с этими двумя фреймворками.

По этой причине у многих Python-разрабов складывается некое подобие тунельного зрения — их инженерный подход заперт между этими двумя библиотеками.

Конечно, Django и Flask — отличные ребята, но довольно таки консервативные. Ведь за последние пару лет мир Python сильно уехал в сторону asyncio, а эти фреймворки так и остались в своей синхронной парадигме.

Часть программистов таки не заперлась между Djano и Flask и добавила в коллекцию своих боевых инструментов модный фреймворк Sanic и aiohttp (не совсем фреймворк, но штука популярная и веб-приложения на нем пилят успешно)


Тектонический сдвиг: от WSGI к ASGI

В период бурной адаптании Python к нуждам веб-разработки, сообщество придумало стандарт WSGI — Web Server Gateway Interface. Этот протокол описывал то, как веб-сервер мог передавать HTTP запросы на обработку в Python приложения и получать оттуда ответы.

WSGI открыл путь для разработки множества фреймворков и библиотек для веб-разработки. Все они были разные по своей архитектуре, но одинаковые по своему способу общения с внешним веб-сервером. WSGI был представлен сообществом аж в 2003-м году и все популярные классические питонячие веб-фреймворки (включая Django и Flask) поддерживают его до сих пор.

Проблемы с WSGI начались после того, как в ядре Python появились мощные средства для асинхронного выполнения кода и корутины. WSGI стар и никак не заточен на работу с новыми фишками языка. Поэтому появилась потребность в новом, асинхронном протоколе общения веб-сервера с Python программами. Так и появился ASGI (Asynchronous Server Gateway Interface) — идеологический потомок WSGI, но с корутинами и асихнронностью.

Разработчики Flask и Django оказались в заложниках своей аудитории — просто так взять и перевести свои фреймворки на асинхронный подход они не могут (это сломает код и уничтожит совместимость), поэтому вся разработка с применением ASGI оказалась сосредоточена в новых фреймворках, выпущенных в последние пару лет.

Вот и получается, что для всех желающих выжать из Python максимум производительности с помощью асинхронности и корутин, переход на новые фреймворки неизбежен.


Starlette — блистательный фреймворк

zpl9o7wewa0yvdjlxlg8kgzwpiu.png

Starlette — новый, шустрый и классные фреймворк, реализующий подход ASGI. В нем все заточено на асинхронность и новые фишки 3-й ветки Python.

Кроме этого, в Starlette есть еще целая пачка серьезных плюшек.


  • GraphQL из коробки. Да-да, этот новый подход к разработке клиент-серверных взаимодействий начинает выдавливать REST и занимает свое место в мире веб-фреймворков.
  • Вебсокеты уже встроены и готовы к работе.
  • Готовый набор миддлверов для работы с авторизацией/аутентификацией, CORS.
  • Встроенные асинхронные таски (подобные Celery)


Солидная примочка — FastAPI

doal9rooo82-mno5pquw8eeijcu.png

Некоторым программистам Starlette дико понравился и они создали расширение для этого фреймворка — FastAPI

FastAPI — это, по сути, нашлепка на родные классы Starlette, добавляющая пачку новых фич к уже и так неплохому фреймворку.


  • Плюшки для создания RESP API сервисов + Swagger документация для методов. Starlette ориентируется на модный GraphQL, FastAPI заботится о тех, кто пилит REST.
  • Удобные примочки, построенные на подсказках-типах переменных. Например, встроенные валидаторы данных.
  • Приятные полезности для процессов авторизации и аутентификации — поддержка JWT, OAuth2.

И еще ряд мелких красивостей и удобностей.


В сухом остатке

Самое время погрузиться в мир ASGI и его фреймворков (если, конечно, вы еще этого не сделали). До доминирования на рынке асинхронным решениям пока далеко, но они активно наступают. И в первую очередь — из-за своей скорости.

© Habrahabr.ru