springmvc+redis实现session共享

Session 共享的简单原理

用户第一次访问应用时,应用会创建一个新的 Session,并且会将 Session 的 ID 作为 Cookie 缓存在浏览器,下一次访问时请求的头部中带着该 Cookie,应用通过获取的 Session ID 进行查找,如果该 Session 存在且有效,则继续该请求,如果 Cookie 无效或者 Session 无效,则会重新生成一个新的 Session

在普通的 JavaEE 应用中,Session 信息放在内存中,当容器(如 Tomcat)关闭后,内存中的 Session 被销毁;重启后如果当前用户再去访问对应的是一个新的 Session ,在多实例中无法共享,一个用户只能访问指定的实例才能使用相同的 Session;

Session 共享实现的原理是将原来内存中的 Session 放在一个需要共享 Session 的实例都可以访问到的位置,如数据库,Redis 中等,从而实现多实例 Session 共享

实现共享后,只要浏览器的 Cookie 中的 Session ID 没有改变,多个实例中的任意一个被销毁不会影响用户访问


Markdown及扩展

  • 在 pom.xml 文件里面添加如下依赖
    jedis版本要和redis版本保持一致,否则可能会有问题

        <dependency>
            <groupId>org.springframework.datagroupId>
            <artifactId>spring-data-redisartifactId>
            <version>2.1.5.RELEASEversion>
        dependency>

        
        <dependency>
            <groupId>org.springframework.sessiongroupId>
            <artifactId>spring-session-data-redisartifactId>
            <version>2.1.4.RELEASEversion>
        dependency>

        
        <dependency>
            <groupId>redis.clientsgroupId>
            <artifactId>jedisartifactId>
            <version>2.10.2version>
        dependency>

添加配置

  • 在resrouce下新建redis.xml配置文件,内容为
    springmvc+redis实现session共享_第1张图片

<beans xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
       xmlns:c="http://www.springframework.org/schema/c"
       xmlns="http://www.springframework.org/schema/beans"
       xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd">

    
    <bean id="jedisConnectionFactory" class="org.springframework.data.redis.connection.jedis.JedisConnectionFactory">
        <constructor-arg>
            <bean class="org.springframework.data.redis.connection.RedisStandaloneConfiguration"
                  c:host-name="redis服务器IP地址" c:port="6379"/>
        constructor-arg>
    bean>

    <bean id="poolConfig" class="redis.clients.jedis.JedisPoolConfig">        
        <property name="minIdle" value="5"/>        
        <property name="maxIdle" value="100"/>        
        <property name="maxTotal" value="300"/>        
        <property name="maxWaitMillis" value="3000"/>        
        <property name="testOnBorrow" value="true"/>
    bean>

    
    <bean id="redisHttpSessionConfiguration"
          class="org.springframework.session.data.redis.config.annotation.web.http.RedisHttpSessionConfiguration" >
        <property name="maxInactiveIntervalInSeconds" value="7200" />
    bean>
beans>

  • 在web.xml中添加过滤器

    <filter>
        <filter-name>springSessionRepositoryFilterfilter-name>
        <filter-class>org.springframework.web.filter.DelegatingFilterProxyfilter-class>
    filter>
    <filter-mapping>
        <filter-name>springSessionRepositoryFilterfilter-name>
        <url-pattern>/*url-pattern>
    filter-mapping>
  • 把redis.xml整合spring,在spring窗口加载时引用redis.xml文件即可。
<import resource="redis.xml"/>

启动项目即可实现session共享。

你可能感兴趣的:(架构)