redis+mongo集成自定义缓存策略

为什么要缓存

  1. 增加响应幅度,
  2. 减轻服务器压力
const mongoose = require("mongoose");
const redis = require("redis");
var client = redis.createClient(7000,"192.168.75.136");
client.on("connect",function (err) {
    if (err) {
        console.log("连接失败");
    }
})

mongoose.connect("mongodb://localhost:27017/yang");
//3.获取连接后的对象 来监听是否连接成功
const conn = mongoose.connection;
conn.on("open",function () {
    console.log("连入成功");
})
conn.on("error",function () {
    console.log("连入错误");
})

//collect 定义好名字,不会乱加s
//auto_reconnect: 链接断开后,是否自动链接
var s1=mongoose.Schema({name:String},{strict:false,versionKey:false,collect:"user",server:{auto_reconnect:true}})
var model = mongoose.model("user",s1);
mongoose.Query.prototype.exec=function(ballback,time){
    var self=this;
    var op = self["op"];//方法名
    var conditions = self["_conditions"];//参数
    var cachekey=op+JSON.stringify(conditions);
    console.log(cachekey);
    client.get(cachekey,function (err,data) {
        if (err) {console.log("获取失败");}
        else {
            if (data) {
                //有缓存
                console.log("有缓存")
                ballback(null,data);
            }else{
                //木有缓存 原生
                self["_"+op](function (err,data) {
                    console.log("没有缓存");
                    ballback(err,data);
                    if(data || data.length!=0){
                        client.set(cachekey,JSON.stringify(data), 'EX', time);
                    }
                });
            }
        }//有缓存,调用缓存的数据直接反馈给
    });
}
model.find({}).exec(function (err,data) {
    if (err) {
        console.log("获取失败");
    }else {
        console.log(data);
        console.log("接收成功");
    }
},60*5);
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值