redis怎么存session

database

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 的全部内容, 来源链接: utcz.com/z/531464.html

回到顶部