-
-
Notifications
You must be signed in to change notification settings - Fork 1.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
rtk-query normalization and manual insert into cache #4106
Comments
As for this point:
Did you enable the autoBatchEnhancer? |
fwiw I wouldn't expect that to help all that much, due to the number of distinct separate calls to Immer. (RTK 2.0 and Immer 10 might help some here, though.) |
Good point. Tbh., your hack here looks interesting, but in the end, it's a hack. At this point, you might be better off to use RTKQ for the "request" part, and maybe have your own normalized state that listens to RTKQ actions. RTKQ will help in a lot of situations, but it isn't always a silver bullet if you really need normalized data. |
I actually came up with this hack over in Reactiflux :) and I did say it was a hack at the time, but it's also valid. The right answer is that we ought to add a multi-item form of |
I did indeed not (yet). I'll try and see if and how much it helps.
I'm well aware but since we're already using Redux within the application for menu/selection states and so on I'd like to stick with one state management tool. We already thought about implementing our own solution but since we're under quite some pressure time-wise we're looking to make amends with the tools we have available.
Indeed and since inserting the whole list is already very fast I guess there should be a way to do this. One question that came up with my colleagues is if it would be possible to defer the cache insertion to a background task or a web worker, so it does not interfere with the UI thread? |
No, afraid not. The store exists on the main thread, so all updates have to be done there. I would love to do some poking into this and see if I can figure out some way to speed it up, but I'm not sure how soon I'll have time to look at it. |
We could change from It is an internal action, so we don't guarantee any api stability on it, we're not nailed to the current implementation. |
@phryneas yeah, that's exactly what I have in mind :) The other issue here is that this particular example requires separate pending/fulfilled actions for each item. So, we're ending up with Sorta related to all this, the current All stuff I'd like to improve over the course of this year! |
@markerikson is there an issue I can track for this action? It is something we are looking to adopt at work as soon as it becomes available. We currently upsert items just in time, but it would be nice to integrate that logic into our RTK Query api without dispatching a large number of actions. |
@StealthySturgeon I'm not immediately sure if we have a specific issue for this already. Per #4107 , our next general step for RTKQ is to triage all the open issues and figure out what things people have asked for so we can start prioritizing the work. Another user has already done the work to fill out a spreadsheet listing all the issues and what each issue is asking for, but we haven't had time to go through it yet. So, this issue will do for now, and if we end up shuffling issues I'll say something here :) |
Tagging here for cross-referencing: someone has an external normalization lib they've tied into RTKQ, per: I have not had time to look into it yet, but will (eventually) when we dig into RTKQ stuff |
Tagging with the word |
@sebastian-dor Hey, I just put up a draft PR with a new util method to batch-upsert cache entries. It's the same basic concept I described and you implemented in this issue, but because it's built in and works via a single action with all the values, the update performance should be much better (say, ~30ms for 1000 items). Could you try out the CodeSandbox CI build from that PR and let me know how that feels? |
Okay, this is out in /~https://github.com/reduxjs/redux-toolkit/releases/tag/v2.3.0 ! |
API has an endpoint that provides a list of items that we need. E.g. we have a map application that shows a lot of structures for a specific scenario id. We then want to use deletion, updating, selecting the items by their respective ID. The way RTK Query builds the cache (key) is by the function name in combination with the (scenario) ID. If one of the items would change, it would invalidate the whole list.
possible solutions:
the makeshift solution for 3.
Creating a so-called top-level reducer in the root reducer that wraps the actual call to the list endpoint and creates fake actions to insert the list items one by one into the cache.
small benchmarks to show the difference between dispatching and insertion via root-reducer:
dispatching 381 took 1130.2000000001863 ms
dispatching 991 took 6271.9000000003725 ms (note that dispatching here crashes the browser anyway)
inserting 381 took 247.5 ms
inserting 991 took 1593.7000000001863 ms
Doing inserts like this for more than 1000 items is not viable that way as it significantly affects user experience. So for now I guess we'll chunk the requests to 1000 at a time. I'm still in the experimentation phase with the solution above, but I do have some ideas to improve the solution here but for now it should work.
Big thanks to @markerikson for help and support!
The text was updated successfully, but these errors were encountered: