Skip to content

Instantly share code, notes, and snippets.

Last active Jan 4, 2020
What would you like to do?
node-redis-mongo - A first cahce file implementation with hook for every query
const mongoose = require("mongoose");
const redis = require("redis");
const util = require("util");
const keys = require("../config/keys");
const client = redis.createClient({
host: keys.redisHost,
port: keys.redisPort,
retry_strategy: () => 1000
client.get = util.promisify(client.get);
const exec = mongoose.Query.prototype.exec;
mongoose.Query.prototype.exec = async function() {
const key = JSON.stringify({
const cacheValue = await client.get(key);
if (cacheValue) {
const doc = JSON.parse(cacheValue);
console.log("Response from Redis");
return Array.isArray(doc)
? => new this.model(d))
: new this.model(doc);
const result = await exec.apply(this, arguments);
client.set(key, JSON.stringify(result));
console.log("Response from MongoDB");
return result;
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment