-
-
Notifications
You must be signed in to change notification settings - Fork 2.1k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
replace http parser? #858
Comments
@danielnelson ^^^ |
aiohttp is the only viable option for using the new uvtools library but aiohttp's http parser is a serious bottleneck at the moment. How can we help fixing this or possibly swapping out the http parser with httptools? |
i will take a look this weekend, should be relative easy to use httptools instead of parser |
added basic integration in @6dae1a28c863e2d0e7ce7b8cda7d3e1c2f3eee0d passes most of the tests from |
Do you see any improvement in performance? |
i am not at that stage yet. need to fix more tests. |
@fafhrd91 I've also added support for HTTP upgrade in v0.0.7. |
@1st1 don't like |
all aiohttp tests pass with new parser |
The code is in the |
yes |
i didn't work on any optimization though |
Interestingly, I don't see any difference in performance ;( |
That means that there is another bottleneck, perhaps even worse than the parser. |
I test it on 3.4.3, I see lower performance with http parser. Maybe http tools should do all headers manipulation and return dictionary. Sent from my iPhone
|
On Python 3.5.1 @ Mac OS X I see roughly equal performance. Doing headers manipulation in httptools will give it a little performance boost, but nothing significant. A rudimentary asyncio HTTP protocol server does 50,000 requests/s on my machine, and aiohttp only 3,300. While aiohttp does more work (supports timeouts, deflate etc) it shouldn't be 15 times (!) slower. httptools parser should be faster than any parser implemented in pure-Python, that's just C vs Python story. If the main bottleneck of aiohttp isn't parsing, it should be something else, I suspect it can be the buffering code. |
i just tried to find bottleneck. replacing aiohttp.web with aiohttp.server increases performance about 70%, |
Do you see any difference of httptools vs pure-Python parser for bare |
no |
Could you please push your code to some experimental branch? |
BTW, did you try to disable aiohttp flow control (CORK)? |
added to replacing |
i also added simple |
Yeah, still, there is a ton of Python code in streams/parsers/etc. While aiohttp architecture is super high-level, flexible and modular, it executes a lot of Python code, and yeah, Python is slow :(. For example, |
Any updates on this, very interesting read?
Does this mean I should try to write all my code just using .server and not using any .web code? |
Basically it means you should profile everything before making any performance assumptions |
@fafhrd91 did you use some flamegraph technique to find the possible bottleneck ? |
@allan-simon no, i didn't. but i don't see reason for doing that, python just slow. any increase of performance in http server code would be neglectable compared to app code. |
@fafhrd91 ok as I was going with the impression you were looking for a bottleneck. Regarding your comment, sure at the end most of the time will be spent in the application code itself, and as a user of the library you should look in your code before trying to switch library. But you also a whole set of microservice that would benefits from high performant http frameworks (for example right now i'm writing one that is streaming a .csv file downloaded form amazon S3 and transforming it on the fly (with some filtering) on a json array (that I can stream too by, one element by line) to assure retro-compatibility, in such case my application code is itself very small and the time spent in the library start to become important. |
we at Keepsafe have plenty on streaming and transforming work, we stream terabytes of data in/out os s3 and aiohttp works pretty well on this load. i just say aiohttp on itself is fast enough but if you need to go faster you need to search other options and those options are outside of python. ps i remember i did a lot of profiling around 0.15 version, and could get 30-50% performance increase in synthetic tests, in there was no any change in performance in real system. (turning off logging gave more increase than any optimizations) |
I see, thanks for the feedback, so your point of view would be that replacing the io loop by uvloop or the http parser is actually not worth the burden ? |
uvloop is worse if you want to write some very low level and simple network protocols, otherwise you just won't see any performance benefits. for high level protocol and complex application it doesn't matter. and again, aiohttp is fast enough, so just use it and write network services :) |
great, thanks for answering all my questions. |
oh just one last question, are you using your applications behind gunicorn or directly behind nginx (with a supervisor or similar taking care of the service life cycle)? |
we use gunicorn and nginx |
@1st1 I am working on parser refactoring. You mentioned idea of removing |
All work is in this pr #1626 |
@asvetlov should we replace http parser with
https://github.com/MagicStack/httptools
?looks good
http://magic.io/blog/uvloop-make-python-networking-great-again/
The text was updated successfully, but these errors were encountered: