1
0
mirror of https://github.com/redis/node-redis.git synced 2025-08-04 15:02:09 +03:00

Client Side Caching (#2947)

* CSC POC ontop of Parser

* add csc file that weren't merged after patch

* address review comments

* nits to try and fix github

* last change from review

* Update client-side cache and improve documentation

* Add client side caching RESP3 validation

* Add documentation for RESP and unstableResp3 options

* Add comprehensive cache statistics

The `CacheStats` class provides detailed metrics like hit/miss counts,
load success/failure counts, total load time, and eviction counts.
It also offers derived metrics such as hit/miss rates, load failure rate,
and average load penalty. The design is inspired by Caffeine.

`BasicClientSideCache` now uses a `StatsCounter` to accumulate these
statistics, exposed via a new `stats()` method. The previous
`cacheHits()` and `cacheMisses()` methods have been removed.

A `recordStats` option (default: true) in `ClientSideCacheConfig`
allows disabling statistics collection.

---------

Co-authored-by: Shaya Potter <shaya@redislabs.com>
This commit is contained in:
Bobby I.
2025-05-19 15:11:47 +03:00
committed by GitHub
parent 6f961bd715
commit f01f1014cb
25 changed files with 2330 additions and 101 deletions

View File

@@ -29,12 +29,7 @@ export function parseGeoSearchArguments(
from: GeoSearchFrom,
by: GeoSearchBy,
options?: GeoSearchOptions,
store?: RedisArgument
) {
if (store !== undefined) {
parser.pushKey(store);
}
parser.pushKey(key);
if (typeof from === 'string' || from instanceof Buffer) {

View File

@@ -17,7 +17,12 @@ export default {
options?: GeoSearchStoreOptions
) {
parser.push('GEOSEARCHSTORE');
parseGeoSearchArguments(parser, source, from, by, options, destination);
if (destination !== undefined) {
parser.pushKey(destination);
}
parseGeoSearchArguments(parser, source, from, by, options);
if (options?.STOREDIST) {
parser.push('STOREDIST');