-
-
Notifications
You must be signed in to change notification settings - Fork 9.4k
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
Explore replacing express with fastify in dev server #17971
Comments
Oooo, I like this idea, in principle. Load times for vite projects in dev can indeed get quite large, especially if Unfortunately, it looks like express (which the storybook dev server uses) still does not support http/2. :(. I kind of would have assumed that http/2 support would be worked out by now. webpack-dev-server, which uses express, also has some challenges. webpack/webpack-dev-server#1713. Fastify seems to be the popular new server on the block, and has support (https://github.com/fastify/fastify/blob/main/docs/Reference/HTTP2.md). But, swapping out the dev server seems like a major change, and I'd want to hear from @shilman and others on the core team what they think before looking into it too much further. |
@IanVS I'd propose we make the on-demand store standard in v7 and then see where we stand. Alternatively if you wanted to prototype a solution and benchmark it against the v7 store, then we could decide whether the perf gain is worth potential compatibility issues that come with switching. |
@shilman that sounds like a good plan. @benatshippabo, would you be interested in investigating what it might take to swap out express to something that supports http/2, like fastify? There is a compat tool for express, so it might be possible to make a phased transition. |
Sounds good, I like the idea of switching to fastify as well. I will keep you posted |
Perhaps we should wait for v4 to be released https://medium.com/@fastifyjs/announcing-fastify-v4-release-candidate-2b6be6edf196 |
Up to you. I think as an exploration / spike, you could probably use the release candidate of V4 to see how much work it is to switch, and what benefits we might get from doing so. Then, if it makes sense to actually make the switch for real, we'd probably want to use a stable v4, but it might be released by then anyway. |
@IanVS migrating from express to fastify looks very plausible based on my investigation thus far. We would only have to change about eleven files: Areas of interestMiddlewaresstorybook/lib/core-server/src/dev-server.ts Lines 36 to 42 in 4c569dd
Fastify
Once we setup something like Static assets
We would need to use Standard routingstorybook/lib/core-common/src/utils/progress-reporting.ts Lines 14 to 34 in 4c569dd
This should be an easy migration using fastify instead of express here should yield the same results. Passing our server to
|
const preview = options.ignorePreview | |
? Promise.resolve() | |
: previewBuilder.start({ | |
startTime, | |
options, | |
router, | |
server, | |
}); | |
const manager = managerBuilder.start({ | |
startTime, | |
options, | |
router, | |
server, | |
}); |
This is where questions arise, I'm not completely sure on the compatibility of passing a fastify instance to our @storybook/builder-*
packages. We may need to update those packages upon switching.
Thanks for the research and for sharing it here. Here's the code we have for dealing with the router and server in @storybook/builder-vite: We mock out the If necessary, we can make a breaking change and require a particular version of builder-vite to be used with newer versions of storybook if this change is made. The webpack builders live in the monorepo and could be updated in lock-step. I'm not aware of any other builders for use with storybook. I'm glad to hear that you think this is doable. It seems like the next step might be to prototype the change with some code, right? I'll be happy to work on the vite builder side of things, and to test it out if you're able to update storybook in a fork. If that makes a big difference in load times, we can get some feedback from the rest of the team and go from there. Does that sound like a plan? |
Hmmm, I tested out http/2 with vite directly, apart from storybook, and from what I can tell, it makes very little difference, unfortunately. My app loads 450 modules on first page load, and the first load happens in about 4.5 seconds regardless of http/1.1 or http/2 (you can start vite with h2 using |
Yeah sounds good, I will probably work on making a pull request that swaps out express for fastify over the next month or so.
That is unfortunate news. I'll still keep working on this and see if it goes anywhere. I will keep you post on any updates @IanVS |
Awesome, thanks! I think if nothing else, it would set us up well for http3/quic, which does appear to have real perf benefits and seems to be getting some activity in node. And fastify will likely add support much faster than express, given the relative pace of development between the two. So yeah, in my opinion this is a good exploration regardless of http2 perf. |
Just a quick update, I've been swamped with other tasks recently. If anyone wants to pick up the work, feel free. |
I've made some progress on a spike. I can load up the manager in a browser with fastify (and without using fastify-express), but am a little bit stuck on gajus/fastify-webpack-hot#3 at the moment. It's too early to tell if there are performance gains yet. |
Status update: I had fastify working briefly, before rebasing onto the latest |
@IanVS Can I assist with that PR some time? |
Yeah that'd be great. I was going to wait until the push for 7.0 was over before I picked it back up, maybe as a 7.1 effort. Are you looking for something to do? :-D |
Hahaha, no I'm no looking for more work, just hoping to assist where I can. 7.1 seems like the right target for this to me. |
any updates on this? |
Is your feature request related to a problem? Please describe
Serving content via http2 is beneficial and greatly improves load times when serving many files. This is the case when using using a no-bundler such as the builder-vite plugin
When using builder-vite, file count can easily exceed 1k files. This causes load times to be 🐌 . We can alleviate this by enabling http2 when appropriate.
Describe the solution you'd like
When running storybook with https enabled:
storybook assets are served via http2
Describe alternatives you've considered
Accept http1.1 bottleneck
Are you able to assist to bring the feature to reality?
yes, I can...
Additional context
The text was updated successfully, but these errors were encountered: