您的位置:首页 > 数据库 > Redis

使用spring-session-data-redis来进行session共享

2017-04-28 00:00 585 查看
摘要: 当单个应用容器节点性能无法再满足需求,可通过session共享来实现应用容器节点扩展。通过调研,发现spring-session-data-redis共享session非常简单,且程序兼容性较好

一、环境准备

##redis安装及配置
linux下安装配置redis可参考链接: https://my.oschina.net/u/2604795/blog/743043

应用容器: tomcat

#二、 maven依赖

<dependency>
<groupId>org.springframework.session</groupId>
<artifactId>spring-session-data-redis</artifactId>
<version>1.2.2.RELEASE</version>
</dependency>
<dependency>
<groupId>redis.clients</groupId>
<artifactId>jedis</artifactId>
<version>2.7.2</version>
</dependency>

#三、配置
##1、web.xml配置

<listener>
<listener-class>
org.springframework.web.context.ContextLoaderListener
</listener-class>
</listener>
<context-param>
<param-name>contextConfigLocation</param-name>
<!-- 路径值自己结合实际配置 -->
<param-value>
/WEB-INF/config/spring/spring-*.xml
</param-value>
</context-param>
<!-- 过滤器 -->
<filter>
<filter-name>springSessionRepositoryFilter</filter-name>
<filter-class>org.springframework.web.filter.DelegatingFilterProxy</filter-class>
</filter>
<filter-mapping>
<filter-name>springSessionRepositoryFilter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>

当项目开发过程中进行单机调试时可将上面的过滤器注释掉,以便调试

##2、spring配置文件

<!-- 对象池配置 -->
<bean id="jedisPoolConfig" class="redis.clients.jedis.JedisPoolConfig">
<property name="maxTotal" value="3"/> <!-- 控制一个pool可分配多少个jedis实例 -->
<property name="maxIdle" value="3" />   <!-- 控制一个pool最多有多少个状态为idle(空闲)的jedis实例 -->
<property name="minIdle" value="1"/>
<property name="maxWaitMillis" value="1000" />  <!-- 表示当borrow一个jedis实例时,最大的等待时间,如果超过等待时间,则直接抛出JedisConnectionException -->
<property name="testOnBorrow" value="false" /> <!-- 在borrow一个jedis实例时,是否提前进行validate操作;如果为true,则得到的jedis实例均是可用的 -->
<property name="testOnReturn" value="false"/>
<property name="testWhileIdle" value="true"/>
</bean>

<!-- 工厂实现 -->
<bean id="jedisConnectionFactory"
class="org.springframework.data.redis.connection.jedis.JedisConnectionFactory"
destroy-method="destroy">
<property name="hostName" value="192.168.133.141" />
<property name="port" value="6380" />
<property name="database" value="0" />
<property name="password" value="123456"/>
<property name="poolConfig" ref="jedisPoolConfig" />
</bean>
<!-- 模板类 -->
<bean id="redisTemplate" class="org.springframework.data.redis.core.RedisTemplate">
<property name="connectionFactory" ref="jedisConnectionFactory"/>
</bean>

<!-- 使用spring-session把http session放到redis里  -->
<bean id="redisHttpSessionConfiguration"
class="org.springframework.session.data.redis.config.annotation.web.http.RedisHttpSessionConfiguration">
<!-- maxInactiveIntervalInSeconds 属性是session的过期时间, 单位秒 -->
<property name="maxInactiveIntervalInSeconds" value="3600" />
</bean>

#四、注意事项
##1、向session存放的数据对象必须是可序列化的对象
存放的数据对象必须实现Serializable接口,且有serialVersionUID属性,不然会出错

##2、maven依赖冲突
spring-session-data-redis依赖冲突时可能导致程序报错
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  Java SpringSession