Skip to content
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

Open
KingWu opened this issue Sep 10, 2020 · 10 comments
Open

Can disable caching? #52

KingWu opened this issue Sep 10, 2020 · 10 comments

Comments

@KingWu
Copy link

KingWu commented Sep 10, 2020

No description provided.

@KingWu KingWu changed the title Disable caching? Can disable caching? Sep 10, 2020
@duong-se
Copy link

duong-se commented Oct 23, 2021

Just have same question, could I disabled caching because it'll cause an issue when we change data

UPDATED:
You can use clear cache by this method

func (r *shipmentResolver) Customer(ctx context.Context, obj *model.Shipment) (*model.Customer, error) {
	customer, err := dataloader.For(ctx).CustomerByID.Load(convertedID)
        // Clear after loaded it
	dataloader.For(ctx).CustomerByID.Clear(convertedID)
	if err != nil {
		// Handle Error
	}
	return customer, nil
}

@frederikhors
Copy link

@tanphamhaiduong can I ask you why Clear() is needed?

@duong-se
Copy link

@tanphamhaiduong can I ask you why Clear() is needed?

Because some entity i need to update frequent, so clear cache to make sure it return correct value for the user

@frederikhors
Copy link

Ok. But I still don't get it. Are you updating that entity frequently during that call?

@sandorvasas
Copy link

sandorvasas commented Jan 10, 2022

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.

@TroyKomodo
Copy link

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.

@TuringJest
Copy link

TuringJest commented Mar 5, 2022

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 .

ldrs = Loaders{
Todos:  newTodoLoader(),

func newTodoLoader() *TodoLoader {
	return &TodoLoader{
		wait:     wait,
		maxBatch: 1000,
		fetch: func(keys []ID) ([]*Todo, []error) {
                         // ... retrieve data
			return todos, errors
		},
	}
}

Also make sure you are using the context as in the example folder.

@TroyKomodo
Copy link

@TuringJest this is not correct.

  1. Why would you want dataloading to be scoped to a single request when you can scope it to the entire application?
  2. If I re-query the dataloader you would assume that the function is rerunning the database queries, if I wanted to implement caching, at a request or app scope, I would have done it in my own code. Limiting the dataloader to be used in this way is quite strange.

@TuringJest
Copy link

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.
If you want to use this with gqlgen you can also find an example in the documentation of the master-branch.

@TroyKomodo
Copy link

@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.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

6 participants