Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/jsumners/node-memcache


https://github.com/jsumners/node-memcache

Last synced: about 1 month ago
JSON representation

Awesome Lists containing this project

README

        

# @jsumners/memcache

This module implements a very simple memory cache that adheres to the core
of the [Catbox (v7)][catbox] protocol. Specifically, it implements the `get`, `drop`,
and `set` methods of the Catbox protocol.

**Caveat:** the storage mechanism is a least recently used cache. So, while
the API uses a time to live mechanic, the maximum number of items in the cache
is capped (default: 100,000). Thus, an item may be removed from the cache
prior to its maximum TTL.

**Important:** this is not meant to be used in a "production" environemnt. It
is meant to fill gaps in testing and/or for a quick way to get started using a
cache that adheres the to protocol.

[catbox]: https://github.com/hapijs/catbox/tree/v7.1.5

## Example

```js
const cacheFactory = require('@jsumners/memcache')
const cache = cacheFactory()

cache.set('foo', 'foo', 300000, (err) => {
if (err) throw err
})

// sometime less that 5 minutes later
cache.get('foo', (err, cached) => {
if (err) throw err
console.log(cached)
// {
// ttl: Number,
// item: Object,
// stored: Number
// }
})
```

## API

Every instance of `key` may be a simple string or a Catbox client compliant
object, e.g. `{id: 'foo', segment: 'bar'}`.

### cacheFactory(maxItems, segment)

Constructor function that is the main export of the module. It will return
a Catbox compliant cache object.

+ `maxItems` (Default: `100000`): sets the maximum number of items that can be
stored in the cache at a given time. Once the limit is reached, the least most
recently used item will be purged to make room for a new item being added.
+ `segment` (Default: `memcache`): sets the default segment to use when defining
cache keys.

#### cache.drop(key, callback)

Remove an item from the cache.

+ `key`: identifier for the object to remove from the cache.
+ `callback(err)`: due to the simple nature of this cache, `err` will always
be `null`.

#### cache.get(key, callback)

Retrieve a value stored in the cache.

Note: if the desired item's lifetime has expired, this method purges the item
from the cache and returns `null`.

+ `key`: identifier for the cached object to retrieve.
+ `callback(err, cached)`: function to invoke after retrieval. `cached` will be
`null` if the item has outlived its lifetime.

#### cache.keys()

Retrieve the list of identifiers for objects stored in the cache.

Note: the cache expires items by simply setting the key to `undefined`. Thus,
it is possible that a key may exist while the associated value does not.

Returns: an `Array` of key identifiers. The keys will be as they have been
mapped internally, e.g.

+ `{id: 'foo', segment: 'bar'}` => `'bar:foo'`
+ `'foo'` => `'memcache:foo'` (with default segment configured)

#### cache.set(key, value, ttl, callback)

Store an item in the cache.

+ `key` (required): an identifier for the value to be stored.
+ `value` (required): the value to be stored.
+ `ttl` (required): the time, in milliseconds, that the stored value should be
valid. There is not a default `ttl`; you **must** supply a `ttl`.
+ `callback(err)`: function to invoke after the item has been stored. Due to the
simple nature of this cache `err` will always be `null`.

## License

[MIT License](http://jsumners.mit-license.org/)