在web开发中,我们经常后听到前端程序员的依据抱怨"又重启了啊?我又要重新登录",这是因为在传统的web开发中,服务器一旦关机,内存中的会话信息会丢失,就跟前端开发存在变量中的数据,浏览器刷新后会丢失一样。为了解决这个问题,引入了session持久化的概念,将服务端和客户端的会话信息保存到一个载体中,不管服务器怎么重启,只要载体中的信息没有丢失,就能拿到会话信息,载体一般为数据库或者文件,但是,得益于redis的特性,我们一般选择用redis作为存储载体。下面是nodejs中用redis做session持久化的例子
// app.js
var session = require('express-session');
var RedisStore = require('connect-redis')(session);
var radisOptions = {
'host': 'localhost',
'port': '6379',
'ttl': 7200, // 存储时间,单位秒,这个时间要和下面session中间件的cookie选项时间一致
'logErrors': false
};
var sessionOptions = {
secret : 'secret', // 对session id 相关的cookie 进行签名
resave : true,
rolling: true,
saveUninitialized: true, // 是否保存未初始化的会话
cookie : {
maxAge : 1000 * 60 * 60 * 2, // 设置 session 的有效时间,单位毫秒 这里设置两小时
},
};
// 生产环境开启持久化存储
if (config.get('enviroment') === 'prod') {
sessionOptions.store = new RedisStore(radisOptions)
}
app.use(session(sessionOptions));
评论 (0)