Redis存储session的需要考虑问题:

session数据如何在Redis中存储?session属性变更何时触发存储? (推荐学习:Redis视频教程)

实现:

考虑到session中数据类似map的结构,采用redis中hash存储session数据比较合适,如果使用单个value存储session数据,不加锁的情况下,就会存在session覆盖的问题,因此使用hash存储session,每次只保存本次变更session属性的数据,避免了锁处理,性能更好。

如果每改一个session的属性就触发存储,在变更较多session属性时会触发多次redis写操作,对性能也会有影响,我们是在每次请求处理完后,做一次session的写入,并且之写入变更过的属性。

如果本次没有做session的更改, 是不会做redis写入的,仅当没有变更的session超过一个时间阀值(不变更session刷新过期时间的阀值),就会触发session保存,以便session能够延长有效期。

两种实现方式:

session集中存储(redis,memcached,hbase等)。

不同服务器上session数据进行复制,两种方式的优缺点,大家应该一目了然。

基于session集中存储的实现方案:

新增Filter,拦截请求,包装HttpServletRequest

改写getSession方法,从session存储中获取session数据,返回自定义的HttpSession实现

在生成新Session后,写入sessionid到cookie中

以上就是redis怎么存session的详细内容,转载自php中文网

点赞(797) 打赏

评论列表 共有 0 条评论

暂无评论

微信小程序

微信扫一扫体验

立即
投稿

微信公众账号

微信扫一扫加关注

发表
评论
返回
顶部