Learn Python with Talk Python's 270 hours of courses

Litestar: Effortlessly Build Performant APIs

Episode #433, published Sun, Oct 15, 2023, recorded Wed, Aug 30, 2023

We all know about Flask and Django. And of course FastAPI made a huge splash when it came on the scene a few years ago. But new web frameworks are being created all the time. And they have these earlier frameworks to borrow from as well. On this episode we dive into a new framework gaining a lot of traction called Litestar. Will it be the foundation of your next project? Join me as I get to know Litestar with its maintainers: Jacob Coffee, Janek Nouvertné, and Cody Fincher.

Watch this episode on YouTube
Play on YouTube
Watch the live stream version

Episode Deep Dive

Guests Introduction and Background

Janek: Former carpenter turned Python developer based in Cologne, Germany. He’s one of the maintainers of Litestar and contributed significantly to its architecture, including key features like WebSocket listeners.

Cody: A longtime database specialist (especially Oracle) who moved into Python and DevOps. He now works at Google as part of their database black belt team and has driven Litestar’s repository patterns and broader data access features.

Jacob: Transitioned from an IT / sysadmin background into DevOps. Recently joined the Litestar team and is learning and contributing to this new, fast-evolving Python framework.


What to Know If You're New to Python

Here are a few essentials for listeners newer to Python so they can follow along with the episode’s details:

  • Understand the concept of async in Python: Litestar and many other modern frameworks rely on async and await to handle many connections efficiently.
  • Be aware of Python’s type hints: This episode highlights frameworks that leverage typing for better data validation.
  • Familiarize yourself with common web frameworks: Names like Django, Flask, and FastAPI come up frequently. Litestar builds on many of their ideas.
  • Know that Python can do more than quick scripts: You’ll hear about entire application structures, from routing to database support.

Key Points and Takeaways

  1. Litestar’s Micro-Framework + Batteries-Included Philosophy Litestar is both minimal and comprehensive. You can build quick, lightweight APIs like you would with Flask, or opt into more opinionated features akin to Django. This unique balance aims to reduce repetitive boilerplate while still allowing customization. It can also handle everything from routing to ORM access with minimal hassle.
  2. High Performance and Benchmarks Litestar places a strong emphasis on speed, especially out-of-the-box JSON serialization using msgspec. Benchmarks discussed compare Litestar to other frameworks like FastAPI, Starlette, and Sanic. The team noted that real-world performance depends on many factors, but Litestar aims to be extremely fast from the start.
  3. Flexible Data Validation (DTOs, Pydantic, and msgspec) Litestar’s data transfer objects (DTOs) let you transform data on the way in or out of your routes—ideal for scenarios like excluding fields or renaming them automatically. While Pydantic is supported, Litestar doesn’t lock you in. You can opt for msgspec or other libraries, matching the validation and speed needs of your project.
  4. Seamless ORM Integration and Repositories Cody’s background with databases influenced Litestar’s repository pattern: You can easily swap or scale from Postgres to Oracle to DuckDB without rewriting your queries. The repository approach also supports advanced features like bulk operations and merges using SQLAlchemy under the hood.
  5. Async and Sync Support By default, Litestar is an async-first framework. However, you can use synchronous (blocking) endpoints either in a separate thread pool or directly in your event loop if there’s no blocking IO. The team emphasizes making you choose intentionally so that you understand any tradeoffs.
  6. WebSockets, Server-Sent Events (SSE), and Channels Litestar abstracts away the complexity of raw WebSockets with listener functions that behave like normal route handlers. This extends to SSE for real-time updates, and a channels-based solution on top of Redis for chat-like fan-out. All are done with strong typing and minimal friction.
  7. Deployment Options and DevOps With modern container orchestration tools (e.g., Kubernetes) or cloud services, some folks run Litestar using just Uvicorn. Others may opt for Gunicorn with multiple workers. The team encourages selecting the approach that best fits your environment.
  8. Version 2.0 Release The recently launched Litestar 2.0 is a major milestone. It removes the Starlette dependency and introduces a host of features such as channels, the new DTO system, a refined plugin architecture for data modeling, and optional Pydantic usage. Many production users, including the hosts, tested it extensively in real-world apps.

Interesting Quotes and Stories

  • On bridging micro frameworks and full-stack: “We definitely have a focus on building APIs... But for us, really important is the effortless part. We strive to take away as much boilerplate as possible.” – Janek
  • On optimizing vs. real-world performance: “Benchmarks measure something, but they often don’t translate perfectly to real-world usage… We just wanted performance out of the box.” – Janek

Key Definitions and Terms

  • DTO (Data Transfer Object): An object that carries data between processes to keep the internal representation separated from outside requests and responses.
  • msgspec: A high-performance Python library for JSON, MessagePack serialization, and data validation, leveraging C under the hood.
  • Channels: A concept borrowed from other frameworks for managing real-time communication, implementing pub/sub patterns (e.g., chat rooms) often backed by Redis.

Learning Resources

If you’d like to deepen your Python web skills or explore the details of modern APIs, here are a few recommended courses from Talk Python Training:


Overall Takeaway

Litestar fills a unique niche by offering the best of micro frameworks’ simplicity with a robust set of optional features. Its second major release marks a leap forward in flexibility, performance, and developer friendliness. Whether you’re exploring real-time features (WebSockets, SSE, channels) or building standard RESTful APIs with minimal boilerplate, Litestar shows there’s plenty of new ground to cover in Python’s web ecosystem.

Links from the show

Guests
Jacob Coffee
Jacob on Github: github.com
Jacob on Twitter: @_scriptr
Jacob on Mastodon: @Monorepo

Cody Fincher
Cody on LinkedIn: linkedin.com
Cody on GitHub: github.com
Email: cody.fincher@gmail.com

Janek Nouvertné
Janek on GitHub: github.com
Email: j.a.nouvertne@posteo.de

Litestar: litestar.dev
Litestar Documentation: litestar.dev
Litestar on Twitter: @LitestarAPI
Litestar on Mastodon: @litestar
Litestar Blog: blog.litestar.dev
Discord: discord.gg
Reddit r/Litestar: eddit.com
Litestar on PyPI: pypi.org
Benchmarks: docs.litestar.dev
v2.0 Release: github.com
gunicorn: gunicorn.org
msgspec: github.com
httpx-sse: github.com
duckdb: duckdb.org
rich-click: github.com
blacksheep server: neoteroi.dev
Watch this episode on YouTube: youtube.com
Episode transcripts: talkpython.fm

--- Stay in touch with us ---
Subscribe to Talk Python on YouTube: youtube.com
Talk Python on Bluesky: @talkpython.fm at bsky.app
Talk Python on Mastodon: talkpython
Michael on Bluesky: @mkennedy.codes at bsky.app
Michael on Mastodon: mkennedy

Talk Python's Mastodon Michael Kennedy's Mastodon