-
Notifications
You must be signed in to change notification settings - Fork 42
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
Patchfox feels much faster #71
Comments
Firefox on my 13" laptop takes 15 seconds to render the inbox html |
Weight of modules on disk
|
Yep, I haven't spent any time focusing on performance and there are lots of low-hanging fruit. These low-hanging fruit have made development faster, but are definitely worth fixing. List of optimizations I'd like to make:
To be specific, the inbox is super slow because it's literally just streaming all private messages until it finds the latest message from the past ~60 threads. The more often you use private messages the faster the view is, but for me it's streaming 6 months of messages to find the oldest one. The 'popular' pages are doing similar work, so they're also super slow. |
Also on the "HTTP requests are kinda slow" front, I've been trying to find a framework like this but I can't find one. Most of Oasis would work 100% fine if it was distributed as a single-page web app (plus it would be easy to demo!) without an actual HTTP server, but I want to leverage an existing technology instead of writing my own. If you know of a tool that would let us port Oasis to an SPA, that might be super helpful. |
Also, because I want to be super super super clear: I think we should prioritize a simple boring HTTP server and probably use it for debugging, but it would be cool to have the option of exporting some standalone |
Relevant for optimizations: https://oasis-demo.fraction.io/thread/%250zK8uZhwMESGFkkf3svywT5cGe6V%2B9qIqHKW5ufLG00%3D.sha256#%250zK8uZhwMESGFkkf3svywT5cGe6V%2B9qIqHKW5ufLG00%3D.sha256 For example, on
Unfortunately this gets more complicated in |
If it was a SPA standalone index.html, would it still need an ssb-client outside the browser? Is it possible to run all of scuttlebutt in a browser? |
I added an experimental branch to mitigate page slowness using turbolinks.js #77 |
I'm not sure that I understand the first question, could you rephrase or add more background info? Regarding the second question, I think yes, because I think that's what @arj03 is doing with SSB-Browser, but when I tried to browserify SSB-DB it blew up in my face. 🤷♂️ I think SSB is supposed to be able to be run in a browser, and I think my first comment about SSB on GitHub was about this use-case, but I don't know how things are going with that. |
I was thinking of https://developer.mozilla.org/en-US/docs/Web/HTTP/Link_prefetching_FAQ |
I really like that idea, I'd be happy to add at least the navigation links to be pre-fetched. |
@christianbundy ssb-db takes a bit more work to run in the browser. There is a branch which was the starting point for ssb-browser-core. Also there is a lot of details like blobs that browser core takes care of. I'm quite happy that it made it to a point where I can add some documentation to make it easier for other people to experiment with clients. Browser demo is around 1500 lines js and that includes the html as its written in vue. Also PWA is great for startup performance because it will load things from cache always and then only afterwards see if the cache is stale. And sorry for hijacking this thread :D |
Awesome, thanks for that info! Do you think that SSB-DB will go back to being platform-agnostic? I could've sworn that we used to be able to browserify it, but it isn't working for me anymore. One of the things I'm trying to do is make sure I'm running the same code in both environments, so that Oasis contributors don't have to worry about whether it's over HTTP or an SPA, but it looks like maybe ssb-browser-core is an alternative to SSB-Server -- is that right? |
In time it will I think. I pushed a few fixes to some of the libraries needed, but on the other hand, having something that only runs in the browser makes it possible to run things like https://github.com/dominictarr/flumelog-aligned-offset without having to worry about backwards compatibility. And yeah ssb-browser-core is probably closer to ssb-server than ssb-db. |
Cool, thanks for all the info @arj03 -- I saw that you mentioned that you're working on something cool on SSB, I'm excited to see what it is. I'm suspicious that it has to do with SSB-Browser. @jedahan Just improved the speed of the inbox page with #79, hope that helps a bit for you! Are there any other big performance hiccups that we should address before closing this issue? |
I spent some time trying to get prefetching working, but had zero success. Happy to close this issue since 'patchfox feels faster' is a bit too broad an issue, and I'd rather pinpoint specific places for performance improvment than something this general. Will test out #79 shortly! |
Woop! Thanks for bringing this up, looking forward to future performance challenges. 👀 |
wow that went from 15 seconds to <1s, awesome job! |
What's the problem you want to solved?
I thought with the simplicity of our client being just html, css, and links, it would be hella fast.
Is there a solution you'd like to recommend?
Maybe we can start writing performance tests, and flamegraphs and all that.
The text was updated successfully, but these errors were encountered: