A TypeScript implementation of a cache clock with TTL based expiry, driven by a single setTimeout
call. Provides simple methods for setting, getting, and deleting cache entries with a chainable API design. By default, the cache is checked every 15 seconds
for expired entries.
- Supports TypeScript
- Built for NodeJS and the browser
- Lightweight and fast (4kb gzipped)
- Built-in automatic cache expiry
- Entries are stored in a
Map
for fast retrieval - Item keys are hashed for fast lookup
- Cache entry statistics
npm:
$ npm install cache-clock
yarn:
$ yarn add cache-clock
const { CacheClock } = require('cache-clock');
// or
const CacheClock = require('cache-clock').CacheClock;
const cache = new CacheClock(config);
import { CacheClock } from 'cache-clock';
const cache = new CacheClock(config);
Note: When intializing a new cache clock, the clock will start immediately. You can opt to not start the clock by passing either passing { autoStart: false } or calling the .stop() method.
import { CacheClock } from 'cache-clock';
const cache = new CacheClock();
cache.set('foo', 'bar');
console.log(cache.get('foo')); // bar
const cache = new CacheClock({
ttl: 10000, // 10 seconds
});
cache.set('foo', 'bar');
// or
const cache = new CacheClock();
cache.set('foo', 'bar', { ttl: 10000 }); // 10 seconds
setTimeout(() => {
console.log(cache.get('foo')); // undefined
}, 11000);
const cache = new CacheClock({
ttl: 10000, // 10 seconds
});
cache.set('foo', 'bar', { ttl: 5000 }); // 5 seconds
const cache = new CacheClock(options);
// or
const cache = CacheClock.create(options);
Returns the age of the cache in milliseconds.
cache.age;
Returns the current size of the cache.
cache.size;
An object
representing the current options of the cache.
cache.options;
Returns a boolean indicating if the cache clock is running.
cache.isRunning;
Update the cache clock configuration. Use this method to update the cache clock configuration after the clock has been initialized. Any items in the cache prior to calling this method will not be affected. It is recommended to instead pass these options when initializing the constructor.
Option | Default | Description |
---|---|---|
maxItems | 1000 | The maximum number of items to store in the cache at once. Exceeding this limit will remove the oldest entry. |
ttl | Infinity | The time to live for all entries in the cache. |
interval | 15000 | The interval in ms to check for expired items. It is recommended to keep this value above 15 seconds for optimal performance. |
onExpire | null | A function to call when an item has expired. |
overwrite | false | Whether to overwrite existing entries. |
resetTimeoutOnAccess | false | When accessing entries via get or has if the expiration should be reset. |
autoStart | true | Programmatically determine if you wish for the clock to auto start. |
debug | false | Log debug messages to the console. Includes success, warning and error messages. |
Note: When passing either Infinity or 0 as the interval, this disables the internal clock. If a clock has already started, once it has finished its current cycle, it will stop.
To preserve false positives when resetTimeoutOnAccess
is true
, the expiration is checked before the timeout is reset. The expiration is also relative to the current time.
Start the cache clock. This is automatically called when the cache clock is created. You should only need to call this method if you have stopped the cache clock manually.
This will spawn a new clock with the full timeout interval. This does not resume the lock from where it left off.
Manually stop the cache clock from running. This will disable the automatic expiration of entries. This does not prevent items from being checked for expiration when using the .get()
or .has()
method.
Create a cache key from the input. This is used internally to create a hash of the key for fast lookup.
cache.set('foo', 'bar', { ttl: 20000 }); // CacheEntry object is returned
When adding new entries, the cache is checked for overflow. If the cache is full, the oldest entry will be removed to make room for the new entry.
Option | Default |
---|---|
overwrite | false |
ttl | false |
Get a cache entry by key. If the entry is not found, undefined
will be returned. If the entry is found, the entry is checked for expiration and removed if expired. Returns the full entry from the cache.
const entry = cache.get('foo');
// {
// k: "foo",
// v: "bar;
// t: 20000;
// e: 1611234567890;
// }
k
- The hashed key of the entryv
- The value of the entryt
- The time to live of the entrye
- The expiry time of the entry
Delete a cache entry by key. If the entry is not found, undefined
will be returned. If the entry is found, the entry is removed from the cache and returned.
const entry = cache.del('foo');
// {
// k: "foo",
// v: "bar;
// t: 20000;
// e: 1611234567890;
// }
Check if a cache entry exists by key. If the entry is not found, false
will be returned. If the entry is found, the entry is checked for expiration and removed if expired. Returns true
if the entry exists.
Clear all entries from the cache.
Returns a JSON representation of the cache.
The cache module now supports internal counters so you can visualise the cache usage. This is useful for debugging and monitoring.
All counters are made available via cache.stats
accessor.
export interface CacheStatistics {
/**
* The number of times the cache was accessed.
*/
hits: number;
/**
* The number of items that were added to the cache.
*/
sets: number;
/**
* The number of times the cache was accessed and
* no item was found.
*/
misses: number;
/**
* The number of items that were removed from the
* cache due to `maxItems` overflowing.
*/
evictions: number;
/**
* The number of items that were removed from the
* cache due to expiration.
*/
expired: number;
/**
* The number of items that were deleted from the
* cache.
*/
deletes: number;
/**
* The number of items that were overwritten.
*/
overwrites: number;
/**
* The number of times the cache was cleared.
*/
clears: number;
/**
* The number of life-cycle events that were triggered.
*/
lifecycles: number;
}
See CHANGELOG.md