You've already forked node-redis
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:
@@ -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) {
|
||||
|
@@ -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');
|
||||
|
Reference in New Issue
Block a user