-
-
Notifications
You must be signed in to change notification settings - Fork 32
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
Poor responsiveness with many torrents or torrents with many files #345
Comments
Did this only recently start or was this already the case before? Do you have a before/after commit difference? I am kind of aware of the file structure thing, I have seen that happen too, I guess it might need some optimization. But I have never seen any issue with the torrent list etc. Then again I don't have such a big collection so it would require some testing to see what's going on. I'm sorry, but I don't think I will have time to look at this soon. But I will definitely have a look when I have the time/energy to do so! ;) |
It wasn't recent AFAIK, I started to notice this trend as more and more torrents were added (over time).
Thank you! 👍 |
I am to experiencing much of the same problems. I'm not sure when it started to happen, but seems like it has steadily become more and more of a problem as the list of torrents I have grow. Currently at around 300, and just doing simple text search takes 2-3 seconds where everything freezes and then it completes the search and resumes again. I tried opening Flood: dd047bd Edit 1: |
Hi! I started experimenting a little with this, but no real luck yet. I created a branch with some attempts though, feel free to have a look: https://github.com/johman10/flood-for-transmission/tree/investigate-performance-issues. What I tried:
Neither of which clearly solved the issue. I'm not sure what the next steps are, but at least I'm able to reproduce it when I throttle my CPU in the Chrome Performance tab. |
I guess the standard thing to do is virtualised tables? It's definitely a last resort thing and shouldn't be needed for 300 rows, but if it's already close to optimal it's a good shot at mitigating performance issues |
Yeah, I was considering it, but I would really rather not. It add a whole bunch of complexity on a fairly simple list. Plus Svelte should be fast, I'm probably just doing something wrong and my guess is that the filters have too many side effects to actually be fast. I would at least like to poke at it more before diving into virtualized lists! :) |
Fair enough, I agree it's a huge pain :) |
I believe you are probably right. I do not believe that we are anyway near pushing enough dom elements currently for that to be the problem, as you mentioned svelte should be fast for this stuff. So instead, there is probably some logic that is faulty, maybe some double iterative list looping or similar. 400 elements even with sub-elements should be fairly simple to render and search through. Heck, using browser builtin CMD-F/CTRL-F works instantly when searching all the text on the page. Here are also some demonstrations from a talk Rich Harris had about svelte comparing how fast it is and how many elements it can render: |
I think the debouncing helped quite a bit here, just like in the example slide you shared. But it isn't great yet. I think what might be the problem is the interlacing of store depedencies which trigger multiple rerenders. I might have to simplify some things in that area to improve it. But I'm not seeing a super straightforward way here as of right now.
This doesn't modify the DOM though, so for that reason it's super fast. However, this is another reason not to use virtualized lists, since it will break that behaviour. Either way, this should be possible, without virtualized lists, but I haven't found the solution yet. If anyone wants to review my code and point out anything that looks off, you're very welcome! :) |
I am now experiencing the issue, too. I don't know if you were able to reproduce it, if not this might help: I'm seeing A LOT of POSTs to
Literally hundreds of them. |
Oh wait, disregard that, sorry, it's just polling and I forgot to mount a volume, it wasn't actually lagging for so long. Sorry 😄 |
Re-posting what I wrote in #561 here instead: I have over 1000 torrents and the UI freezes for a couple seconds whenever I change the sort column/filter with lots of torrents showing. I tried building and running the dev version to do some profiling but I don't know enough about frontend dev and even less about Svelte to figure much out. I tried deleting the contents of the Here's a tarball with 1500 torrents I generated so you can easily reproduce this: torrents.tar.gz Thanks for the project, I've been using it for a while and really like it but performance is unfortunately making it hard to use nowadays. |
Hi everyone! The UI uses a polling approach to fetching torrents, and before if the previous request wasn't finished a new request would start anyway. With the changes in #558 this should not happen anymore, which could have a positive effect on the performance overall. I would love to have some feedback on this if you have any. Has the performance improved, has it degraded or remained the same? Please let me know as input for further improvements down the line. |
I forgot to try that release when you posted, and finally remembered... |
Hello, I have about 100 torrents and it takes 1s for any action with the latest release 2024-05-18T08:04:58 |
@mocxi can you please clarify what kind of connection you are on? What kind of bandwith do you have? Please test with a service like: https://fast.com/. Can you also confirm whether you have a similar issue with the default Transmission UI or not? |
Hello,
Not sure I get it but I'm using TCP connection. the bandwith is about 170Mbps but I always limit my torrent at 40Mbps so it's should be 40 Mbps and 16 torrents are acting. not happening with default UI or Transmissionionic. |
Poor UI responsiveness with a ~400 torrent library, with most buttons or actions taking 1 second to respond to user input.
In torrents with a lot of files (15.000 ?), selecting which files to download from the menu that comes out when double-clicking a torrent entry can take more than 10 seconds to list and perform any action such as select/unselect/etc.
I've tested with Firefox and Chromium and the issues are present in both browsers (Chromium is running without any extensions).
Transmission version: 3.00
flood-for-transmission version: c4bbb0c
The text was updated successfully, but these errors were encountered: