session为何须要持久化

为何须要持久化:
  客户端访问了某个能开启会话功能的资源, web服务器就会建立一个与该客户端对应的HttpSession对象,每一个HttpSession对象都要站用必定的内存空间。若是在某一时间段内访问站点的用户不少,web服务器内存中就会积累大量的HttpSession对象,消耗大量的服务器内存,即便用户已经离开或者关闭了浏览器,web服务器仍要保留与之对应的HttpSession对象,在他们超时以前,一直占用web服务器内存资源。web


  web服务器一般将那些暂时不活动但未超时的HttpSession对象转移到文件系统或数据库中保存,服务器要使用他们时再将他们从文件系统或数据库中装载入内存,这种技术称为Session的持久化。
  将HttpSession对象保存到文件系统或数据库中,须要采用序列化的方式将HttpSession对象中的每一个属性对象保存到文件系统或数据库中;将HttpSession对象从文件系统或数据库中装载如内存时,须要采用反序列化的方式,恢复HttpSession对象中的每一个属性对象。因此存储在HttpSession对象中的每一个属性对象必须实现Serializable接口数据库


 

Session的持久化的做用:
  1.提升服务器内存的利用率,保证那些暂停活动的客户端在会话超时以前继续原来的会话
  2,在多台web服务器协同对外提供服务的集群系统中,使用Session的持久化技术,某台服务器能够将其中发生改变的Session对象复制给其余服务器。保证了在某台服务器中止工做后能够由其余服务器来接替它与客户端的会话
  3,在一个web应用程序重启时,服务器也会持久化该应用程序中全部HttpSession对象,保证客户端的会话活动仍能够继续。apache


Tomcat使用Session Manager 类来管理Session的持久化,他提供了两个SessionManager类
org.apache.catalina.session.StandardManager
org.apache.catalina.session.PersistentManager
StandardManager是tomcat默认使用的,在web应用程序关闭时,对内存中的全部HttpSession对象进行持久化,把他们保存到文件系统中。默认的存储文件为
<tomcat 安装目录>/work/Catalina/<主机名>/<应用程序名>/sessions.ser
PersistentManager比StandardManager更为灵活,只要某个设备提供了实现org.apache.catalina.Store接口的驱动类,PersistentManager就能够将HttpSession对象保存到该设备浏览器

相关文章
相关标签/搜索