spring session整合

本文涉及的产品
云数据库 Redis 版,社区版 2GB
推荐场景:
搭建游戏排行榜
简介:

花了大半天时间,解决了springMVC项目增加spring-session共享session报了异常

java.lang.ClassNotFoundException:com.lambdaworks.redis.AbstractRedisClient
java.lang.ClassNotFoundException:com.lambdaworks.redis.RedisException

前情

项目做了前后端分离,springMVC项目部署在三台tomcat上,前端部署在另三台tomcat上,然后HA做了分发处理,使一个用户访问后,后面的访问都会是其中的某一台tomcat... 理想是美好的,现实中,会出现登录前后会有连接是访问了不同的tomcat,我没有运维权限,也不想接这个坑,所以就从代码上处理吧。
代码上怎么处理呢,我觉得很简单,session共享不就行了,使用spring-session超简单,几行代码就搞定了。注意:这里的超简单是在spring-boot中使用才超简单。spring-boot中使用redis共享session配置:
1、pom.xml加依赖

        <dependency>
            <groupId>org.springframework.session</groupId>
            <artifactId>spring-session</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.session</groupId>
            <artifactId>spring-session-data-redis</artifactId>
        </dependency>

2、application.properties加配置:

spring.session.store-type=redis

搞定
但是,我的项目不是spring-boot项目,所以参考官网说的配吧。我的部署环境jdk是1.7、tomcat7,所以sprint-session 2.0.x是肯定不能支持了,所以还是使用1.3.3吧,官网手册
很简单,有web.xml,所以配置分2步:
1、 在spring-context.xml中加上配置:

<context:annotation-config/>
<bean class="org.springframework.session.data.redis.config.annotation.web.http.RedisHttpSessionConfiguration"/>
<bean class="org.springframework.data.redis.connection.lettuce.LettuceConnectionFactory"/>

2、在web.xml加上

<context-param>
    <param-name>contextConfigLocation</param-name>
    <param-value>
        /WEB-INF/spring/*.xml
    </param-value>
</context-param>
<listener>
    <listener-class>
        org.springframework.web.context.ContextLoaderListener
    </listener-class>
</listener>

当然,要在pom.xml上加上依赖包

<dependency>
    <groupId>org.springframework.session</groupId>
            <artifactId>spring-session</artifactId>
            <version>1.3.0.RELEASE</version>
        </dependency>
        <dependency>
            <groupId>org.springframework.session</groupId>
            <artifactId>spring-session-data-redis</artifactId>
            <version>1.3.0.RELEASE</version>
        </dependency>

然后...
就是报了异常

java.lang.ClassNotFoundException:com.lambdaworks.redis.AbstractRedisClient

java.lang.ClassNotFoundException:com.lambdaworks.redis.RedisException

我知道是会有版本兼容的问题,所以不断切换版本试试看,然后就试了大半天,结果再一仔细看配置:知道com.lambdaworks是哪个包不:io.lettuce。所以的,其实是因为我使用的是jedis包,所以根本不需要这一行代码

<bean class="org.springframework.data.redis.connection.lettuce.LettuceConnectionFactory"/>

解决

因为我使用的是jedis包,而不是也不需要用到io.lettuce包,所以在spring-context.xml中配置应该是这样的:

    <!-- Redis 线程池配置 -->
    <bean id="jedisPoolConfig" class="redis.clients.jedis.JedisPoolConfig">
        <property name="maxTotal" value="${redis.pool.maxActive}" />
        <property name="maxIdle" value="${redis.pool.maxIdle}" />
        <property name="maxWaitMillis" value="${redis.pool.maxWaitMillis}" />
        <property name="testOnBorrow" value="${redis.pool.testOnBorrow}" />
    </bean>
    <bean id="jedisConnFactory"
        class="org.springframework.data.redis.connection.jedis.JedisConnectionFactory">
        <property name="hostName" value="${redis.hostname}" />
        <property name="password" value="${redis.password}" />
        <property name="port" value="${redis.port}" />
        <property name="usePool" value="${redis.usePool}" />
        <property name="poolConfig" ref="jedisPoolConfig" />
    </bean>
    <!-- spring-session共享支持 -->
    <context:annotation-config/>
    <bean class="org.springframework.session.data.redis.config.annotation.web.http.RedisHttpSessionConfiguration" />
相关实践学习
基于Redis实现在线游戏积分排行榜
本场景将介绍如何基于Redis数据库实现在线游戏中的游戏玩家积分排行榜功能。
云数据库 Redis 版使用教程
云数据库Redis版是兼容Redis协议标准的、提供持久化的内存数据库服务,基于高可靠双机热备架构及可无缝扩展的集群架构,满足高读写性能场景及容量需弹性变配的业务需求。 产品详情:https://www.aliyun.com/product/kvstore &nbsp; &nbsp; ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库&nbsp;ECS 实例和一台目标数据库&nbsp;RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&amp;RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
相关文章
|
7月前
|
存储 NoSQL Java
Spring Session分布式会话管理
Spring Session分布式会话管理
50 0
|
3月前
|
存储 NoSQL Redis
spring-session-core排除某些接口不设置session
spring-session-core排除某些接口不设置session
34 0
|
7月前
|
Java Spring
Spring Boot 中的 Session 是什么,如何使用
Spring Boot 中的 Session 是什么,如何使用
|
7月前
|
缓存 NoSQL Java
Spring Session MongoDB管理会话
Spring Session MongoDB管理会话
60 0
|
9月前
|
安全 Java Spring
SpringBoot整合Spring Security,使用Session方式的验证码(六)
这里用到了一个常量类,到时候做验证码判断时用的比较多:
89 0
|
9月前
|
设计模式 缓存 NoSQL
简述 Spring Session 集成 Redis 底层实现及自定义扩展配置
简述 Spring Session 集成 Redis 底层实现及自定义扩展配置
331 0
|
11月前
|
NoSQL Java Redis
Spring Session - 源码解读
Spring Session - 源码解读
242 0
|
11月前
|
存储 JSON NoSQL
Spring Session - 使用Spring Session从零到一构建分布式session
Spring Session - 使用Spring Session从零到一构建分布式session
148 0
|
11月前
|
存储 NoSQL Java
Spring Session - Cookie VS Session VS Token 以及 Session不一致问题的N种解决方案
Spring Session - Cookie VS Session VS Token 以及 Session不一致问题的N种解决方案
115 0
|
11月前
|
存储 NoSQL Java
Spring Session中存放于Redis中的PRINCIPAL_NAME_INDEX_NAME没有设置过期时间
Spring Session中存放于Redis中的PRINCIPAL_NAME_INDEX_NAME没有设置过期时间
238 0