Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Speaker Deck
PRO
Sign in
Sign up for free
Everybody loves Benchmarks (Lightning Talk) by Nickolas Grigoriadis
Pycon ZA
October 12, 2018
0
45
Everybody loves Benchmarks (Lightning Talk) by Nickolas Grigoriadis
A talk about Python Http client performance.
Pycon ZA
October 12, 2018
Tweet
Share
More Decks by Pycon ZA
See All by Pycon ZA
Trio: Structured Concurrency for Python by Jeremy Thurgood
pyconza
0
100
Preparing for the great snakes migration by Heather Williams
pyconza
0
24
Satellite Data and Super-Resolution to enhance a Slope Soaring Simulator by Schalk Heunis
pyconza
0
72
"Should we just go home on the third Friday afternoon?" by Kim van Wyk
pyconza
0
39
"Dolosse: Distributed Physics Data Acquisition System" by Bertram Losper & Sehlabaka Qhobosheane
pyconza
0
63
Modern JavaScript for Python Developers by Cory Zue
pyconza
0
170
Making Art with Python by Kirk Kaiser
pyconza
0
110
"Posits: A proposed new floating point number format for ML" by Kevin Colville
pyconza
0
48
"Building a label printer using Python, Arduino, duct tape and paperclips" by Johan Beyers
pyconza
0
110
Featured
See All Featured
Adopting Sorbet at Scale
ufuk
65
7.7k
10 Git Anti Patterns You Should be Aware of
lemiorhan
642
53k
Code Reviewing Like a Champion
maltzj
507
38k
Templates, Plugins, & Blocks: Oh My! Creating the theme that thinks of everything
marktimemedia
15
1.1k
Docker and Python
trallard
27
1.8k
The MySQL Ecosystem @ GitHub 2015
samlambert
239
11k
Six Lessons from altMBA
skipperchong
15
1.5k
"I'm Feeling Lucky" - Building Great Search Experiences for Today's Users (#IAC19)
danielanewman
214
20k
Building Better People: How to give real-time feedback that sticks.
wjessup
344
17k
The Invisible Customer
myddelton
111
11k
Making Projects Easy
brettharned
101
4.6k
Rebuilding a faster, lazier Slack
samanthasiow
64
7.4k
Transcript
1 Everybody loves Benchmarks A quick show of Python HTTP
client performance. Nickolas Grigoriadis
2 We all love Python But a common complaint is
it is slow. Especially for HTTP requests.
3 Common mistakes Create a new “session” for each request:
requests.get(...) Instead do: session = requests.session() # Now re-use session session.get(...)
4 Benchmarks • Done on my old i5-630u notebook. •
Single process. • Against Apache (because I could turn HTTP/1.1 pipelining on/off) • Inside an Alpine-linux Docker container. https://github.com/vibora-io/benchmarks/pull/5
5 Benchmarks! - sync requests requests (opt) urllib3 urllib3 (opt)
PyCurl PyCurl (opt) 0 2000 4000 6000 8000 10000 12000 HTTP/1.0 — 1 HTTP/1.1 — 1
6 Benchmarks! - async aioHTTP aioHTTP (opt) aioHTTP (+uvloop) tornado.simple
tornado.simple (+uvloop) tornado.curl tornado.curl (+uvloop) vibora.client 0 500 1000 1500 2000 2500 3000 3500 4000 4500 HTTP/1.0 — 1 HTTP/1.1 — 1 HTTP/1.0 — 10 HTTP/1.1 — 10