使用spring-session-data-redis来进行session共享
2017-04-28 00:00
585 查看
摘要: 当单个应用容器节点性能无法再满足需求,可通过session共享来实现应用容器节点扩展。通过调研,发现spring-session-data-redis共享session非常简单,且程序兼容性较好
linux下安装配置redis可参考链接: https://my.oschina.net/u/2604795/blog/743043
应用容器: tomcat
#二、 maven依赖
#三、配置
##1、web.xml配置
当项目开发过程中进行单机调试时可将上面的过滤器注释掉,以便调试
##2、spring配置文件
#四、注意事项
##1、向session存放的数据对象必须是可序列化的对象
存放的数据对象必须实现Serializable接口,且有serialVersionUID属性,不然会出错
##2、maven依赖冲突
spring-session-data-redis依赖冲突时可能导致程序报错
一、环境准备
##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依赖冲突时可能导致程序报错
相关文章推荐
- 使用Spring Session redis进行Session共享
- Spring boot入门系列(三):使用Redis进行Session的管理
- 使用spring-data-redis进行对redis的操作,封装的一些操作方法
- 使用spring-data-redis进行对redis的操作,封装的一些操作方法
- 使用Spring-data进行Redis操作
- spring-session-data-redis使用redis共享session
- spring-data-redis 使用 protobuf进行序列化和反序列
- 使用Spring-data-redis操作Redis的Sentinel
- 使用Spring Data +Redis实现缓存
- 使用spring-session把http session放到redis里面
- spring-data-redis 使用
- 6、redis之使用spring-data-redis的Template
- spring-data-redis使用自定义序列化数据 使用 protobuf
- Chapter 1. 使用Spring进行数据访问(Data Access With Spring)
- 【Redis基础】SSH 中Spring-data-redis使用体验
- 使用spring-data-redis开发redis应用
- 使用spring-data-redis操作Redis的Sentinel
- 在spring data jpa中使用redis的通用list及entity存储方法
- Spring+redis,spring-data-redis使用
- 使用Spring-Data-Redis存储对象(redisTemplate)