-
Notifications
You must be signed in to change notification settings - Fork 79
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
Can disable caching? #52
Comments
Just have same question, could I disabled caching because it'll cause an issue when we change data UPDATED:
|
@tanphamhaiduong can I ask you why |
Because some entity i need to update frequent, so clear cache to make sure it return correct value for the user |
Ok. But I still don't get it. Are you updating that entity frequently during that call? |
Need to be able to disable caching. Causing issues for us immediately right after deploy. User changed its name, but the old user name is getting loaded. Not good. I would don't need caching at all. It's causing more problems than it solves. |
I am unsure why caching is even implemented at all. Caching should and always should be controlled by the developer. If i wanted to add caching I would have implemented it in the data loader step, when i fetch the data from the database, ie checking redis or a in memory cache. I am likely going to have to fork to remove this functionality and it this feature should be seriously reconsidered. |
The caching is intended to work per request and not to be long-lived. To make sure this works properly you have to return a new dataloader for every request .
Also make sure you are using the context as in the example folder. |
@TuringJest this is not correct.
|
The caching that happens on a request level doesn't stop you to use your own global caching solution to retrieve data inside the dataloader. It just ensures that the data returned in one request is consistent in all cases and not re-queried if requested multiple times across one request. But you can check https://github.com/graph-gophers/dataloader which offers to disable caching completely. |
@TuringJest I think you miss-understood. There is no way to have a global data loader without caching, your proposed solution to get around the caching of recreating it per request is not global. I fixed this problem by forking it and removing the caching aspects. Caching here is stupid, because every application has different requirements and different needs, perhaps a better way to approach this is to allow a ARGV flag which disables the caching code generation, although I didn't do this because I don't really need caching at all. This library is better than the graph-gophers lib because this is a code generator which means all the logic is run and confirmed at compile time (which is better) than running and checking logic at runtime (which is error prone). They both do data loading but generally being able to force types at compile time is far superior than forcing them at runtime. |
No description provided.
The text was updated successfully, but these errors were encountered: