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

[redis] use scan to iterate keys #418

Open
1 task
Rigo-m opened this issue Mar 27, 2024 · 6 comments
Open
1 task

[redis] use scan to iterate keys #418

Rigo-m opened this issue Mar 27, 2024 · 6 comments
Labels
enhancement New feature or request

Comments

@Rigo-m
Copy link

Rigo-m commented Mar 27, 2024

Describe the feature

Working with large redis db, you might encounter an error if you try to fetch too many keys altogether.
There should be a scan option available (or getKeys should be implemented via scan)

Additional information

  • Would you be willing to help implement this feature?
@pi0
Copy link
Member

pi0 commented Mar 28, 2024

Would you please share runnable reproduction?

@Rigo-m
Copy link
Author

Rigo-m commented Mar 28, 2024

Hi pi0, using upstash as a redis provider
https://stackblitz.com/edit/nuxt-starter-ako5kk?file=server%2Fapi%2Ferror-redis.ts this simple script triggers the error when using getKeys.

Actually, as a second thought, I'm not sure whether the error is from upstash which is prohibiting reading that many keys altogether (since it is a blocking operation https://redis.io/commands/keys/) or whether it is a redis limitation.
Can I do anything else?

@pi0 pi0 changed the title Missing Scan feature for keys in redis driver [redis] upstash shows error when accessing too many keys May 1, 2024
@pi0
Copy link
Member

pi0 commented May 1, 2024

Hi @chronark do you know if it is a known limitation? And what would you suggest to scan too many keys?

@pi0 pi0 changed the title [redis] upstash shows error when accessing too many keys [redis] use scan to iterate keys Dec 18, 2024
@pi0 pi0 added enhancement New feature or request and removed needs investigation labels Dec 18, 2024
@ps-20x
Copy link

ps-20x commented Jan 7, 2025

For redis maybe there should be a match (scan) function that returns the keys by a matching pattern similar to the native scan function (https://redis.io/docs/latest/commands/scan/). The function could get the matching pattern (e.g. *name*), an optional a cursor (initial value 0) and an optional count (initial value is 10) similar to the native scan.

For us it is also not possible to work with the cache in vercel at the moment because we have too many entries (Error:

ERR KEYS command is disabled because total number of keys is too large, please use SCAN

@pi0
Copy link
Member

pi0 commented Jan 7, 2025

Good idea, we might use match if base/maxDepth is provided.

I don't have time to immedtialy jump on it but feel free to open a PR 👍🏼 (it might be easiest if we introduce this behavior behind a driver flag to move forward faster)

@ps-20x
Copy link

ps-20x commented Jan 13, 2025

Good idea, we might use match if base/maxDepth is provided.

I don't have time to immedtialy jump on it but feel free to open a PR 👍🏼 (it might be easiest if we introduce this behavior behind a driver flag to move forward faster)

Thanks for your response. Unfortunately we needed a solution for this asap. So we went around it and used our PHP Backend to connect to the redis and remove it from there. So I currently can't look into it. Maybe I'll find some time on the weekends.

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

No branches or pull requests

3 participants