阅读 687

spring session整合

原文链接: click.aliyun.com

花了大半天时间,解决了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 " />复制代码
文章分类
后端