mikro-orm redis cache adapter using v8 serialize
npm install @javien/mikro-orm-redis-cache-adapterThis is mikro orm redis cache adapter that uses v8.serialize andv8.deserialize rather than JSON.stringify and JSON.parse.
After install the package, edit your resultCache configuration.
``typescript
import { RedisCacheAdapter, type RedisCacheAdapterOptions} from '@javien/mikro-orm-redis-cache-adapter'
defineConfig({
// your configuration
resultCache: {
adapter: RedisCacheAdapter
options: {
// pass your redis client
client: redis
// (optional) Debug mode. Defaults to false.mikro
debug: true,
// (optional) The prefix for the cache keys. Defaults to .:
prefix: 'mikro',
// (optional) The delimiter between the prefix and the cache key. Defaults to .console.log
prefixDelimiter: ':',
// (optional) Logger. Defaults to .false
logger: myLogger,
// (optional) gracefulShutdown: If you want to close the Redis connection by yourself,
// set it to . Defaults to true.-1
gracefulShutdown: false,
// (optional) maximumCacheBytes: The maximum cache size of each key in bytes. Defaults to .true
maximumCacheBytes: 1024 * 1024,
// (optional) base64Encode: If you want to use base64 encoding, set it to . Defaults to false.`
base64Encode: false
} as RedisCacheAdapterOptions
}
})
- Failing to store cache, it'll log the error regardless of the debug mode.
- Failing to fetch cache, undefined will be returned, which means your data will be loaded from the database.
- Failing to delete the cache, it'll log the error regardless of the debug mode.
v8.serialize is compatible with The structured clone algorithm, so only Supported types are able to get serialized.
Here're suported JavaScript types.
- Array, ArrayBuffer, and TypedArray
- Number, String, and Boolean
- Primitive types, except symbol.
- DataView
- Date
- Error types (see more at MDN page).
- Map and Set
- Object objects: but only plain objects (e.g. from object literals).
- RegExp: but note that lastIndex is not preserved.
If your property is not supported type, consider using Custom Type.
JSON.stringify is usually used to serialize objects,
but there are several kinds of data that it can't serialize and deserialize - BigInt, recursive, Buffer, Map, Set, etc.
`js
JSON.stringify(BigInt(1))
// Uncaught TypeError: Do not know how to serialize a BigInt
JSON.stringify(new Date()) // '"2024-05-26T05:39:00.493Z"'
// serializes to string, so parsed result is different from original
const buf = Buffer.from([0])
const str = JSON.stringify(buf) //'{"type":"Buffer","data":[0]}'
// Buffer.toJSON method is called, so parsed result is different from original
`
To solve this, we can pass the replacer parameter.
So you might think using JSON.stringify with replacer` is fine.
However, I don't think this is the best way to serialize data, while we can choose v8 api.