SlideShare a Scribd company logo
asyncio-stack for web-
development
Misha Behersky
About
Python developer @ DataRobot
2
Benchmark [1]
3
Benchmark
4
Database drivers
● aiocouchdb
● aiomysql
● aioredis
● aiozmq
● aioes
● aiopg
● aiokafka
● aioodbc
● aiomcache
5
SQLAlchemy
6
Faster postgre client?
$ pip install asyncpg
7
Mongo? [2]
8
aiohttp_jinja2
9
aiohttp_debugtoolbar
10
aiohttp_debugtoolbar
$ pip install aiohttp_debugtoolbar
11
aiohttp_debugtoolbar
12
aiohttp_debugtoolbar
13
aiohttp_debugtoolbar
14
aiohttp_session
● SimpleCookieStorage
● EncryptedCookieStorage
● RedisStorage
15
aiohttp_session
16
aiohttp_security
● AbstractIdentityPolicy
● AbstractAuthorizationPolicy
● remember()
● forget()
● authorized_userid()
● permits()
17
aiohttp_security
18
aiohttp_security
19
Slowloris
$ nmap --script http-slowloris-check
127.0.0.1 -p 8080
20
Web-sockets [3]
21
Middleware
22
Middleware
23
aiohttp client [4]
24
aiohttp_admin
25
aiohttp_admin
26
Other tools [5]
● aiohttp_runserver
● aiohttp_cors
● aiohttp_traversal
● aiothrottle
● aiohttp_mako
● and more ...
27
Project structure
28
Debug
$ export PYTHONASYNCIODEBUG=1
● explicit loop
● releasing resources
● awaititng coroutines
$ python script.py -Wdefault
29
Debug
$ Task was destroyed but it is pending!
task: <Task pending coro=<fetch_bad() running at demo.py:
14> wait_for=<Future pending cb=[Task._wakeup(),
BaseSelectorEventLoop._sock_connect_done(10)()]>>
30
Debug
$ ConnectionResetError: [Errno 54] Connect call failed
('127.0.0.1', 8080)
$ OSError: [Errno 24] Too many open files
31
Debug
32
Testing
33
Testing
34
Testing [6]
35
Go production!
$ gunicorn app_module:app
--bind localhost:8080 --worker-class
aiohttp.worker.GunicornWebWorker
36
Graceful shutdown
37
Production architecture 38
Resources
1. klen.github.io/py-frameworks-bench/
2. emptysqua.re/blog/
3. igordavydenko.com/talks/lvivpy-5/
4. pawelmhm.github.io/asyncio/python/aiohttp/2016/04/22/asyncio-aiohttp.html
5. github.com/python/asyncio/wiki/ThirdParty
6. asvetlov.github.io/pytest-slides/
7. http://www.slideshare.net/mariczhuck/
39
Thanks for your attention
https://github.com/kpidata/webcamp16
bmwant@gmail.com
@bmwant
bmwlog.pp.ua
40
Let’s have some fun!
my-mail [ at ] gmail [ dot ] com
41
Eyjafjallajokull
PyPI
42

More Related Content

PDF
WebCamp 2016: Python. Михаил Бегерский: Использование asyncio-стека для разра...
PDF
Anwendungsfälle für Elasticsearch JAX 2015
PDF
窺探職場上所需之資安專業技術與能力 Tdohconf
PPTX
如何利用 Docker 強化網站安全
PDF
Redis way of Anayltics with Python - Fifth Elephant 2012
KEY
Node workShop Basic
PDF
Anwendungsfälle für Elasticsearch JavaLand 2015
PPTX
Redis fundamental
WebCamp 2016: Python. Михаил Бегерский: Использование asyncio-стека для разра...
Anwendungsfälle für Elasticsearch JAX 2015
窺探職場上所需之資安專業技術與能力 Tdohconf
如何利用 Docker 強化網站安全
Redis way of Anayltics with Python - Fifth Elephant 2012
Node workShop Basic
Anwendungsfälle für Elasticsearch JavaLand 2015
Redis fundamental

What's hot (6)

PPTX
Introduction to node js
PPTX
Don't let just Node.js take the blame
PPTX
Build & test Apache Hawq
PPTX
Hunting Performance Problems in Node.js and beyond
PPTX
Иван Новиков «Elastic search»
PDF
Log file analysis by Peter Nikolow
Introduction to node js
Don't let just Node.js take the blame
Build & test Apache Hawq
Hunting Performance Problems in Node.js and beyond
Иван Новиков «Elastic search»
Log file analysis by Peter Nikolow
Ad

Similar to asyncio stack for web-development (20)

PDF
How to Shot Web - Jason Haddix at DEFCON 23 - See it Live: Details in Descrip...
PDF
Managing and Visualizing your Replication Topologies with Orchestrator
PDF
Openshift: Deployments for the rest of us
PDF
EuroPython 2013 - Python3 TurboGears Training
KEY
PyCon AU 2012 - Debugging Live Python Web Applications
PDF
Using RIPEstat
PPTX
Free5 gc installation
PDF
Sprint 138
PDF
Skyfall b sides-c00-l-ed5-sp-2013
PDF
Android best practices 2015
PDF
2020 ADDO Spring Break OWASP ZAP Automation
PDF
Blazor introduction
PDF
手把手教你如何串接 Log 到各種網路服務
PDF
Kettunen, miaubiz fuzzing at scale and in style
PPTX
Python on pi
PDF
JBoss EAP 7 & JDG 7 최신 기술 소개
PDF
Virtualization Management The oVirt Way (August Penguin 2015)
PDF
Workshop KrakYourNet2016 - Web applications hacking Ruby on Rails example
KEY
Study2study#4 nginx conf_1_24
PPTX
Write an API for Almost Anything: The Amazing Power and Flexibility of Django...
How to Shot Web - Jason Haddix at DEFCON 23 - See it Live: Details in Descrip...
Managing and Visualizing your Replication Topologies with Orchestrator
Openshift: Deployments for the rest of us
EuroPython 2013 - Python3 TurboGears Training
PyCon AU 2012 - Debugging Live Python Web Applications
Using RIPEstat
Free5 gc installation
Sprint 138
Skyfall b sides-c00-l-ed5-sp-2013
Android best practices 2015
2020 ADDO Spring Break OWASP ZAP Automation
Blazor introduction
手把手教你如何串接 Log 到各種網路服務
Kettunen, miaubiz fuzzing at scale and in style
Python on pi
JBoss EAP 7 & JDG 7 최신 기술 소개
Virtualization Management The oVirt Way (August Penguin 2015)
Workshop KrakYourNet2016 - Web applications hacking Ruby on Rails example
Study2study#4 nginx conf_1_24
Write an API for Almost Anything: The Amazing Power and Flexibility of Django...
Ad

Recently uploaded (20)

PDF
Building Integrated photovoltaic BIPV_UPV.pdf
PDF
Shreyas Phanse Resume: Experienced Backend Engineer | Java • Spring Boot • Ka...
PDF
Machine learning based COVID-19 study performance prediction
PDF
Advanced methodologies resolving dimensionality complications for autism neur...
PPTX
KOM of Painting work and Equipment Insulation REV00 update 25-dec.pptx
PDF
Dropbox Q2 2025 Financial Results & Investor Presentation
PPTX
Understanding_Digital_Forensics_Presentation.pptx
PDF
Review of recent advances in non-invasive hemoglobin estimation
PDF
CIFDAQ's Market Insight: SEC Turns Pro Crypto
PDF
Blue Purple Modern Animated Computer Science Presentation.pdf.pdf
PDF
Encapsulation_ Review paper, used for researhc scholars
PDF
Electronic commerce courselecture one. Pdf
PDF
Reach Out and Touch Someone: Haptics and Empathic Computing
PDF
TokAI - TikTok AI Agent : The First AI Application That Analyzes 10,000+ Vira...
PDF
NewMind AI Monthly Chronicles - July 2025
PDF
The Rise and Fall of 3GPP – Time for a Sabbatical?
DOCX
The AUB Centre for AI in Media Proposal.docx
PPTX
Digital-Transformation-Roadmap-for-Companies.pptx
PDF
Approach and Philosophy of On baking technology
PDF
NewMind AI Weekly Chronicles - August'25 Week I
Building Integrated photovoltaic BIPV_UPV.pdf
Shreyas Phanse Resume: Experienced Backend Engineer | Java • Spring Boot • Ka...
Machine learning based COVID-19 study performance prediction
Advanced methodologies resolving dimensionality complications for autism neur...
KOM of Painting work and Equipment Insulation REV00 update 25-dec.pptx
Dropbox Q2 2025 Financial Results & Investor Presentation
Understanding_Digital_Forensics_Presentation.pptx
Review of recent advances in non-invasive hemoglobin estimation
CIFDAQ's Market Insight: SEC Turns Pro Crypto
Blue Purple Modern Animated Computer Science Presentation.pdf.pdf
Encapsulation_ Review paper, used for researhc scholars
Electronic commerce courselecture one. Pdf
Reach Out and Touch Someone: Haptics and Empathic Computing
TokAI - TikTok AI Agent : The First AI Application That Analyzes 10,000+ Vira...
NewMind AI Monthly Chronicles - July 2025
The Rise and Fall of 3GPP – Time for a Sabbatical?
The AUB Centre for AI in Media Proposal.docx
Digital-Transformation-Roadmap-for-Companies.pptx
Approach and Philosophy of On baking technology
NewMind AI Weekly Chronicles - August'25 Week I

asyncio stack for web-development