分布式Session的几种实现方式

本文介绍了session的基本概念,包括创建与销毁的机制,并详细探讨了分布式环境下实现Session共享的多种方式,如数据库、NFS、memcached、web容器复制、TT/Redis、cookie等解决方案。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一:session简介

在 JAVA WEB开发中,服务器可以为每个用户浏览器创建一个会话对象(session对象),注意:一个浏览器独占一个session对象(默认情况下)。因此,在需要保存用户数据时,服务器程序可以把用户数据写到用户浏览器独占的session中,当用户使用浏览器访问其它程序时,其它程序可以从用户的session中取出该用户的数据,为用户服务。

二:session的创建

resquest.getSession()获取session对象,但对于session是否创建,分两种情况。

一是请求中无session id,会创建session对象

二是请求中有session id 的值,如果在服务器端,有一个session id的值与其一样,不会创建,直接使用。如果在服务器端,没有对应的session id 值,会创建session对象。 

三:session的销毁(四种)

1,默认超时,30分钟

2,设置session超时时间,setMaxInactiveInterval(int time)

3,手动销毁,执行invalidate()

4,关闭服务器

四:分布式Session的几种实现方式

1,基于数据库的session共享

2,基于NFS共享文件系统

3,基于memcached的session

4,基于resin/tomcat web容器本身的session复制机制
5,基于TT/Redis 或 jbosscache 进行 session 共享。

6,基于cookie 进行session共享



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值