一.在开发机安装redis并远程连接

因本人的远程开发机配置原因,使用jumbo安装redis

    1. 首先登录开发机,并使用jumbo 安装redis:jumbo install redis
    2. 查看redis各文件路径: jumbo list-files redis
    3. 确认redis-server 及 redis.conf的路径后启动redis:  ~/.jumbo/bin/redis-server ~/.jumbo/etc/redis.conf  (通过修改conf 文件中 daemonize 为 yes,可后台启动redis)
    4. 使用redis-cli 在控制台可进入redis: ~/.jumbo/bin/redis-cli
    5. 退出并关闭redis:  ~/.jumbo/bin/redis-cli shutdown
    6. 配置redis的远程连接:还是修改conf文件,
          将 bind 127.0.0.1 改为 bind 0.0.0.0 
          将protected-mode 改为 no
          将requirepass 注释放开并设置密码
    7. 远程连接redis: 本机安装redis完毕后,使用 redis-cli -h xxx.xxx.xxx.xx(远程ip)  -p 80xx(远程端口) -a xxxxx(远程密码)   进入远程redis数据库

二、ioredis

通过使用ioredis,可以方便的进行node对redis进行操作,包说明如下:https://www.npmjs.com/package/ioredis

通过其封装的管道操作pipeline 实现redis的事务操作

ioredis使用如下所示:

 export default {
port:8079,
host:'xxxxx',
family:4,
password:'123456',
retryStrategy(times){
return Math.min(times*50,2000);
},
reconnectOnError(err){
if(err.message.slice(0,8) == 'READONLY'){
return true;
}
}
} const redis = new Redis(conf);

其中redis对象即可以进行redis数据库中的所有操作,如 set get hmset hgetall 等等,参数的传入形式及顺序与redis-cli命令行中的一致。

三、koa2中session的管理

koa2中session管理有方便的node包,koa-session 、koa-session2等等,通过配置koa-session/koa-session2 中的store属性,即可将redis和session对象关联到一起。

 /**
* 配置store对象的get set destroy属性即可操作session对象
* 通过简单读取session.xxx 即可触发get方法,session={...} 即可触发set方法 session = null 或重置 session即可触发destroy方法
* koa-session 与 koa-session2区别在于 koa-session2支持 async/await同步操作
* koa-session2 需要extends Store才能使用
*/
// koa-session配置如下 export default {
async get(key, maxAge, { rolling }){
// console.log('get',key,maxAge,rolling);
let res = await redis.hgetall(key).then(r=>r).catch(e=>{
{error:e}
});
return res;
console.log('get',res);
},
async set(key, sess, maxAge, { rolling, changed }){
console.log('set',key,sess,maxAge,rolling,changed);
if(changed){
let seconds = Math.floor(maxAge/1000);
redis.hmset(key,sess);
redis.expire(key,seconds);
}
},
async destroy(key){
console.log('destory',key);
await redis.del(key);
}
} //koa-session2 class RedisStore extends Store {
constructor(){
super();
}
async get(key,ctx){
// console.log('get',key,maxAge,rolling);
let res = await redis.hgetall(key).then(r=>r).catch(e=>{
{error:e}
});
return res;
}
async set(session, { sid = this.getID(24), maxAge = 1000000 } = {}, ctx){
console.log('set',session.openid,maxAge,sid);
let seconds = Math.floor(maxAge/1000);
await redis.hmset(sid,session);
await redis.expire(sid,seconds);
return sid;
}
async destroy(key,ctx){
console.log('destory',key);
await redis.del(key);
}
}
let store = new RedisStore();
export default store;

在koa应用中作为中间件引入的方式如下

 let sessConf = Object.assign({},CONF,{store});
app.use(session(sessConf)); // koa-session2 app.use(session(sessConf,app)) // koa-session

四、redis中session的expire时间顺延

当用户在站内不断操作的时候,session需要一直维持,不能过期。待用户停止操作时,则在设定的相应时间后使存储在redis中的session过期,使用户重新登录。

 let {cookies} = ctx;
let key = cookies.get('kris_sess'); // 保存session key 的cookie
if(key && ctx.session.openid){
cookies.set('kris_sess',key,{
maxAge:60*1000
}); // 对cookie进行延期
redis.expire(key,60*1000); // 对redis session存储进行延期
.....
}

nodejs 使用redis 管理session的更多相关文章

  1. nodejs express下使用redis管理session

    Session实现原理 实现请求身份验证的方式很多,其中一种广泛接受的方式是使用服务器端产生的Session ID结合浏览器的Cookie实现对Session的管理,一般来说包括以下4个步骤: 服务器 ...

  2. 用Redis管理Session

    maven <dependency> <groupId>redis.clients</groupId> <artifactId>jedis</ar ...

  3. Shiro经过Redis管理会话实现集群(转载)

    原文:http://www.myexception.cn/software-architecture-design/1815507.html Shiro通过Redis管理会话实现集群 写在前面 1.在 ...

  4. 在nodejs使用Redis缓存和查询数据及Session持久化(Express)

    在nodejs使用Redis缓存和查询数据及Session持久化(Express) https://segmentfault.com/a/1190000002488971

  5. Tomcat7基于Redis的Session共享实战二

    目前,为了使web能适应大规模的访问,需要实现应用的集群部署.集群最有效的方案就是负载均衡,而实现负载均衡用户每一个请求都有可能被分配到不固定的服务器上,这样我们首先要解决session的统一来保证无 ...

  6. 【荐】PHP Session和Cookie,Session阻塞,Session垃圾回收,Redis共享Session,不推荐Memcached保存Session

    什么是 Session 在 web 应用开发中,Session 被称为会话.主要被用于保存某个访问者的数据. 由于 HTTP 无状态的特点,服务端是不会记住客户端的,对服务端来说,每一个请求都是全新的 ...

  7. ASP.NET下跨应用共享Session和使用Redis进行Session托管简介

    在之前的博客中,我说到了Session的共享问题,其中说到了Web Farm和Web Garden两种情况下Session的处理.在ASP.NET提供的Session处理方法中,有以下四种模式: 1. ...

  8. 单点登录实现(spring session+redis完成session共享)

    一.前言 项目中用到的SSO,使用开源框架cas做的.简单的了解了一下cas,并学习了一下 单点登录的原理,有兴趣的同学也可以学习一下,写个demo玩一玩. 二.工程结构 我模拟了 sso的客户端和s ...

  9. 超好用的Redis管理及监控工具,使用后可大大提高你的工作效率!

    Redis做为现在web应用开发的黄金搭担组合,大量的被应用,广泛用于存储session信息,权限信息,交易作业等热数据.做为一名有10年以上JAVA开发经验的程序员,工作中项目也是广泛使用了Redi ...

随机推荐

  1. Python十六进制转码问题

    使用Python的decode函数转码十六进制的字符串时,会出现UnicodeDecodeError: 'utf8' codec can't decode byte 0xba in position ...

  2. Python fileinput模块详解

    Python的fileinput模块可以快速对一个或多个文件进行循环遍历. import fileinput for line in fileinput.input(): process(line) ...

  3. [洛谷P1440]求m区间内的最小值

    题目大意:给你n个数,求出每个数前m位的最小值 题解:单调队列,用一个可以双向弹出的队列来存一串数,满足里面的数具有单调性,我们可以假设它是单调递增的,即求最小的数.那么可以把要插入的这个数与队尾元素 ...

  4. CC DGCD:Dynamic GCD——题解

    https://vjudge.net/problem/CodeChef-DGCD https://www.codechef.com/problems/DGCD 题目大意: 给一颗带点权的树,两个操作: ...

  5. 2017 ccpc哈尔滨 A题 Palindrome

    2017 ccpc哈尔滨 A题 Palindrome 题意: 给一个串\(T\),计算存在多少子串S满足\(S[i]=S[2n−i]=S[2n+i−2](1≤i≤n)\) 思路: 很明显这里的回文串长 ...

  6. jQuery考试

    No1: 分析:首先A答案是正确的jQuery中删除元素的方法有a,c,d所以排除B,另外c是清空,d虽然能删除但是不能删除元素所绑定的事件等等. No2: 分析:A是正确的通过get(index)的 ...

  7. Efficient Deblurring for Shaken and Partially Saturated Images

    Try the online demo: http://willow-fd.rocq.inria.fr/unshake/ Overview One common feature of “shaken” ...

  8. NYOJ 737DP

    石子合并(一) 时间限制:1000 ms  |  内存限制:65535 KB 难度:3   描述     有N堆石子排成一排,每堆石子有一定的数量.现要将N堆石子并成为一堆.合并的过程只能每次将相邻的 ...

  9. STM32之窗口看门狗

    1.有个7位递减计数器(WWDG->CR),就这个计数器和窗口计数器(WWDG->CFR)决定什么时候喂狗.狗喂早了,复位——“早”体现在 计数器值(tr)>窗口值(wr),也就是计 ...

  10. Linux(CentOS6.7) 安装MySql5.7数据库 图文教程

    linux(CentOS6.7) 环境Mysql 5.7.17安装教程分享给大家,供大家参考,具体内容如下: 1系统约定安装文件下载目录:/data/softwareMysql目录安装位置:/usr/ ...