-
Notifications
You must be signed in to change notification settings - Fork 654
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
HTTPHeaders.description is unnecessarily slow #2930
Comments
I've looked at the code base a bit on swift-nio/Sources/NIOHTTP1/HTTPTypes.swift Line 315 in 19da487
Maybe I am not looking at the proper type? |
You are and that's the problem.
or something similar, then it should be much faster. We should discuss the format we want to return here. CC @Lukasa WDYT, format for HTTP headers for |
We can do that, though the resolution of that format is poor: it'll mishandle some things that are otherwise fine. But for a first order approximation that output is ok. |
@supersonicbyte folks are sometimes slow to respond here, and if you're still interested, I'd suggest you go for it and just know that it might not get merged. My personal experience was that I made my first PR and then @weissi and @glbrntt were unreasonably generous with their time and attention, guided me through the process, and helped me onboard. If you don't have time to continue, though, I'll be happy to pick this up. |
Motivation: As outlined in this [issue](apple#2930) by @weissi, the current performance of calling `description` on `HTTPHeaders` is undermined by the dynamism of Array. Modifications: The proposed solution replaces the implementation of `description` to iterate over the items and print them out manually. This provides a faster solution since we bypass the cost of calling into `description` of an Array. Result: A more performant implementation of `HTTPHeaders` description.
Hey everyone, I made a PR for this. |
### Motivation: As outlined in this [issue](#2930) by @weissi, the current performance of calling `description` on `HTTPHeaders` is undermined by the dynamism of Array. ### Modifications: The proposed solution replaces the implementation of `description` to iterate over the items and print them out manually. This provides a faster solution since we bypass the cost of calling into `description` of an Array. ### Result: A more performant implementation of `HTTPHeaders` description. --------- Co-authored-by: Johannes Weiss <[email protected]> Co-authored-by: Cory Benfield <[email protected]>
Expected behavior
HTTPHeaders.description should be reasonably fast and shouldn't do any dynamic
debugPrint(...)
Actual behavior
It's slow. Look at this image: about 15% of the overall runtime of a client hitting
/dynamic/info
is just spent doing header printing...That's largely because of
debugPrint
etc.Printing HTTP headers is somewhat common and shouldn't be unnecessarily fast. The representation could also be nicer.
The text was updated successfully, but these errors were encountered: