@ddatabase/cache

1.0.2 • Public • Published

@ddatabase/cache

A caching module for dDatabase tree nodes and blocks.

This module mplements the hashlru algorithm internally for LRU caching, but it uses byte length estimates instead of the entry count for eviction.

Installation

npm i @ddatabase/cache --save

API

const cache = new DDatabaseCache(opts = {})

Creates a new cache.

Options can include:

{
  maxByteSize: 1e6,  // The soft maximum size of the cache (actual max size can go up to 2x this value).
  estimateSize: val => { ... },  // A function from a value to its size estimate.
  onEvict: (evicted) => { ... }  // A hook that's called when stale entries (a Map) have been evicted.
}

cache.set(key, value)

Sets key to value.

cache.get(key)

Gets the value for key.

cache.del(key)

Deletes key from the cache.

const subCache = cache.namespace()

Creates a namespaced sub-cache which mirrors the @ddatabase/cache API.

This is useful if you want to create a single cache instance that manages resources for multiple dDatabases.

License

MIT

Readme

Keywords

Package Sidebar

Install

npm i @ddatabase/cache

Homepage

dwebx.org

Weekly Downloads

6

Version

1.0.2

License

MIT

Unpacked Size

13.4 kB

Total Files

7

Last publish

Collaborators

  • dwebprotocol