Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
Our code uses an Cache interface so we just need to implement another implementation of the cache interface for valkey.
Most of the work is renaming everything from redis to valkey.
The tests that use an actual instance in lib/valkeycache/cache_test.go needed no modifications besides renaming.
With this, we can use the latest version of valkey: 8.0. Whereas it seems we are stuck on redis version 7.2 beforehand (redis has 7.4 out).
One thing that is notable, the valkey client uses strings and []byte. We tend to like []byte instead. So what I did was restrict this implementation to []byte values.
From a Terraform perspective, I just followed the examples from the docs. Previously, we had a 1GB instance. Now, we have a 1.4GB instance (via the
SHARED_CORE_NANO
node type). That is the smallest instance type. Pricing wise shouldn't really matter. The instance will be slightly cheaper (4 cents per hour vs 6 cents per hour). Valkey Pricing vs Redis Pricing. I think the network pricing will be the same based on usage.