-
Notifications
You must be signed in to change notification settings - Fork 30.2k
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
Feature Idea: Brotli support in core #18964
Comments
Sounds like a good idea to me. I’m somewhat familiar with /cc @MayhemYDG |
+1 p.s. if we're adding more compression stuff in core perhaps we should put it under one builtin module name |
to be honest this may be the point where we decide if we want to use a nodejs namespace... as there is already a |
I think it makes sense. IMO Node, as a web server, should strive to support low-level modern web features, much like http2. |
Yes, please. Brotli usage in Node.js has been held back by the barrier of native modules, this would certainly allow for broader adoption. |
Pinging this to see if anyone is interested in taking this on as an action item |
It seems weird that "can I use" and download numbers are enough for adding brotli, but were never enough for adding websockets |
@vkurchatkin tbh I think that we should revisit adding websockets. If we look at the original thread #1010 some of the people who originally were -1 changed their opinions. In fact we ship a partial implementation of ws already, and have an open EPS exploring adding it nodejs/node-eps#6 The original decision by the TC at the time was to rather implement lower level buffer method, but that was abandoned. I thinks I'll open another issue to discuss edit: issue for reference #19308 |
Hello, Which kind of skillset would it require? Would someone be willing to mentor me if I want to try it? |
Quick question: why would this need to be added to core vs user land? Is there a notable perf improvement or impl improvement to be gained relative to the userland module? |
This originally came up in a conversation with @kristoferbaxter where they mentioned having issues with userland implementations, and a lack of support in core being a reason for companies / enterprises to not adopt the format despite performance improvements compared to zlib. I'm paraphrasing and will let them chime in |
Hi there. There are a few userland implementations with differing drawbacks, but the most prominent are iltorb and wasm-brotli afaik. iltorb – https://github.com/MayhemYDG/iltorb Pros: Works well for those who can leverage the pre-compiled binaries. Supports compression options. wasm-brotli – https://github.com/dfrankland/wasm-brotli Pros: No need for a pre-built binary. TLDR; |
Aside from the convenience factor around native modules, are there specific performance or other ease of implementation considerations? |
Convenience might be understating this. Every installation of Lowering the cost to try out brotli compression might allow a greater number of transmissions to be compressed using it versus gzip. For end users this can be a meaningful difference.
The specific performance concerns mostly relate to usage of
The API of Let's flip the question around a bit too, if common compression schemes like brotli should not be in core... should gzip implementations? Should http2? The larger question of what should be in core is hard to answer. I'm certainly not qualified to answer it, but am happy to share my experiences. Edit: Added link for performance data. Sorry for updating without saying what was updated! |
Cool thank you for the details. Please don't take my questions as push back, just need to build the case for the addition |
No worries, never came across that way to me! Thanks for taking a look and hopefully this helps to explain a bit more why this might be a good idea. |
If I understand this properly, we could bind to the V8implementation of Brotli? (I'm sorry if my question is stupid, all of this is quite new to me) |
V8 doesn't include Brotli. Chromium does. But yeah would be interesting to see how wasm performs. Also, hi @MayhemYDG! |
Oh ok, so it's writing our own binding to Node. Is there a standard way or an example I could read about this? |
Maybe take a look at how zlib binding is done? |
Also, there is already one. https://github.com/MayhemYDG/iltorb |
There's an open pull request now, #20458. I'm curious if anyone has usage numbers of brotli on the internet. I've been tracking my own internet usage but it's almost exclusively *.google.com that sends brotli back. Guess that makes sense with it being a Google thing. |
Using the BigQuery query mentioned here (see the BigQuery guide here), there were 33K domains found using Brotli. For comparison that linked discussion post found only 357 domains when run in November 2016. I've exported the top 500 domains by frequency (it refused to export the full list) to: (For anyone wanting to repeat the above, the query only uses 5.8GB of BigQuery analysis allowance, and the first 1TB per month is free.) |
For anyone else wondering, that means just shy of 7% of the top 500k websites serve up brotli. More than I'd expected. |
@MylesBorins, @addaleax, #24938 landed, can this be closed now? |
Taking a quick peek at "can i use" shows that brotli is now supported on Edge, Firefox, Chrome, Safari, and iOS Safari.
The iltorb package has 912k downloads a month.
The brotli npm package has 250k download a month
If people are open to this I would be willing to collaborate on a patch to add this functionality.
The text was updated successfully, but these errors were encountered: