Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
Async, Python, and the Future
Search
Sponsored
·
Ship Features Fearlessly
Turn features on and off without deploys. Used by thousands of Ruby developers.
→
Andrew Godwin
March 23, 2021
Programming
720
2
Share
Async, Python, and the Future
A keynote I gave at Python Web Conference 2021.
Andrew Godwin
March 23, 2021
More Decks by Andrew Godwin
See All by Andrew Godwin
Reconciling Everything
andrewgodwin
1
380
Django Through The Years
andrewgodwin
0
300
Writing Maintainable Software At Scale
andrewgodwin
0
510
A Newcomer's Guide To Airflow's Architecture
andrewgodwin
0
400
How To Break Django: With Async
andrewgodwin
1
790
Taking Django's ORM Async
andrewgodwin
0
790
The Long Road To Asynchrony
andrewgodwin
0
750
The Scientist & The Engineer
andrewgodwin
1
830
Pioneering Real-Time
andrewgodwin
0
490
Other Decks in Programming
See All in Programming
レガシーPHP転生 〜父がドメインエキスパートだったのでDDD+Claude Codeでチート開発します〜
panda_program
0
870
PHPのバージョンアップ時にも役立ったAST(2026年版)
matsuo_atsushi
0
310
瑠璃の宝石に学ぶ技術の声の聴き方 / 【劇場版】アニメから得た学びを発表会2026 #エンジニアニメ
mazrean
0
240
VueエンジニアがReactを触って感じた_設計の違い
koukimiura
0
170
ローカルで稼働するAI エージェントを超えて / beyond-local-ai-agents
gawa
3
270
RSAが破られる前に知っておきたい 耐量子計算機暗号(PQC)入門 / Intro to PQC: Preparing for the Post-RSA Era
mackey0225
3
130
의존성 주입과 모듈화
fornewid
0
130
Radical Imagining - LIFT 2025-2027 Policy Agenda
lift1998
0
280
ネイティブアプリとWebフロントエンドのAPI通信ラッパーにおける共通化の勘所
suguruooki
0
260
PDI: Como Alavancar Sua Carreira e Seu Negócio
marcelgsantos
0
120
PCOVから学ぶコードカバレッジ #phpcon_odawara
o0h
PRO
0
260
mruby on C#: From VM Implementation to Game Scripting (RubyKaigi 2026)
hadashia
1
180
Featured
See All Featured
Making Projects Easy
brettharned
120
6.6k
How To Stay Up To Date on Web Technology
chriscoyier
790
250k
Exploring anti-patterns in Rails
aemeredith
3
320
YesSQL, Process and Tooling at Scale
rocio
174
15k
The Straight Up "How To Draw Better" Workshop
denniskardys
239
140k
What’s in a name? Adding method to the madness
productmarketing
PRO
24
4k
[RailsConf 2023 Opening Keynote] The Magic of Rails
eileencodes
31
10k
Being A Developer After 40
akosma
91
590k
Design and Strategy: How to Deal with People Who Don’t "Get" Design
morganepeng
133
19k
Everyday Curiosity
cassininazir
0
190
Creating an realtime collaboration tool: Agile Flush - .NET Oxford
marcduiker
35
2.4k
GitHub's CSS Performance
jonrohan
1032
470k
Transcript
ASYNC, PYTHON, AND ANDREW GODWIN // @andrewgodwin THE FUTURE
Hi, I’m Andrew Godwin • Django core developer • Worked
on Migrations, Channels & Async • Dabbled with Python async since 2009
None
The Past What is all this async business anyway? The
Present The long road and where we've got to The Future Is there a perfect solution to all this?
The path was forged by other languages And continues to
be - we're all one community in the end
1998 threading module, Stackless Python 2002 Twisted 2006 Greenlets (later
gevent, eventlet) 2008 multiprocessing module 2012 Tulip, PEP 3156 2014 asyncio module 2005 Coroutine-friendly generators (PEP 342)
Threading & Multiprocessing They're concurrency, but not really "async" in
the way we use it now
Twisted The original, and ahead of its time!
Greenlets & Gevent An almost drop-in solution… but it's never
that easy
Generators & Tulip The foundation of our current, cooperative async
1998 threading module, Stackless Python 2002 Twisted 2006 Greenlets (later
gevent, eventlet) 2008 multiprocessing module 2012 Tulip, PEP 3156 2014 asyncio module 2005 Coroutine-friendly generators (PEP 342)
What did we learn? A lot, but not everything.
Let's talk about the present And, of course, asyncio
Asyncio is here, and it's gaining traction Library support! Framework
support!
# Ready when a timer finishes await asyncio.sleep(1) # Ready
when network packets return await client.get("http://example.com") # Ready when the coroutine exits await my_function("hello", 64.2)
Network/timer updates An event loop's flow Select a ready task
Run task Add new tasks to queue await
Coroutines Time →
It is, however, not yet perfect. Turns out, it's a
really hard problem to solve
Everything must cooperate! One bit of synchronous code will ruin
the whole thing.
Can't tell if a function returns a coroutine! There are
standard hints, but no actual guaranteed way
async def calculate(x): result = await coroutine(x) return result #
These both return a coroutine def calculate(x): result = coroutine(x) return result
Can't have one function service both How we got here
makes sense, but it's still annoying sometimes.
You have to namespace async functions I really, really wish
we didn't have to
instance = MyModel.objects.get(id=3) instance = await MyModel.objects.a.get(id=3)
WSGIHandler __call__ WSGI Server WSGIRequest URLs Middleware View __call__ ASGIHandler
__call__ ASGI Server ASGIRequest Asynchronous request path BaseHandler get_response_async BaseHandler get_response URLs Middleware Async View __call__ Django's dual request flows
But, in many ways, the future is here You can
just write full async Python now, and it works pretty well.
So what does the future hold? Apart from, in my
case, a very delicious meal.
Obviously, more library support Databases & common services are still
thin on the ground
Safety, Safety, Safety Async code is HARD. Really hard.
How do we design out silent failure? Deadlocks, livelocks, race
conditions...
How do we prioritise? It's not like you have all
day to add new things.
Horizontal scalability is more important It's the difference between life
and death for a web service.
Long-polling and sockets need async Or your server bill will,
instead, be the death of you
I think we need both Sync and async code both
have their place.
Some things don't need async They're better off a little
slower and safer
Asyncio only benefits IO-bound code Code that thrashes the CPU
doesn't benefit at all
What does this mean for the Web? Our roles are
changing along with our technology
Parallel Queries After all, we're the experts in fetching data
Notifications & Events Polling will absolutely wreck your servers Microservices / API aggregation It's a lot quicker to call those 10 things in parallel
What does this mean for you? You're probably not in
quite as deep as I am
Mixed-mode is coming Django has it, Flask is really close.
Think about your architecture Group things that all do I/O
& requests together, for future parallelisation
Experiment! Take some async code for a spin.
Be the change you want to see. There's a lot
of work to be done, and never enough of us to do it.
Thanks. Andrew Godwin @andrewgodwin // aeracode.org