spring session,集群环境下的session共享解决方案

之前在集群环境下需要解决session共享的问题,更多的时候我们是使用servlet容器例如tomcat提供的集群配置来解决session的复制问题。今天介绍一种简单的解决方案。

http://docs.spring.io/spring-session/docs/current/reference/html5/guides/httpsession.html#updating-dependencies
这里有关spring session的详细介绍,其使用起来也相当简单。

1:在pom文件中引入spring session的相关依赖

<dependency>
                <groupId>org.springframework.sessiongroupId>
                <artifactId>spring-session-data-redisartifactId>
                <version>1.1.1.RELEASEversion>
                <type>pomtype>
        dependency>
        <dependency>
                <groupId>org.springframeworkgroupId>
                <artifactId>spring-webartifactId>
                <version>4.2.5.RELEASEversion>
        dependency>
dependencies>

2 由于官网给出的是一种java代码配置的方式,在项目中,我们更多的是使用配置的方式来进行spring session的配置。因而我们需要搜索相关资料进行配置。
1:在web.xml的配置文件中加载spring-session的配置文件,比如spring-session.xml。

 <filter>
        <filter-name>springSessionRepositoryFilterfilter-name>
        <filter-class>org.springframework.web.filter.DelegatingFilterProxyfilter-class>
    filter>
    <filter-mapping>
        <filter-name>springSessionRepositoryFilterfilter-name>
        /*
    filter-mapping>

注意事项:这个filter的配置应该在web工程的其他filter配置之前。

    <context-param>
        <param-name>contextConfigLocationparam-name>
        <param-value>
            classpath:spring-session.xml
        param-value>
    context-param>
    <listener>
        <listener-class>
            org.springframework.web.context.ContextLoaderListener
        listener-class>
    listener>

加载该配置文件,可以和其他配置文件一起加载,以逗号隔开即可。例如:

<param-value>classpath:spring-servlet.xml,classpath:customer.xml</param-value>

2:在spring-session.xml的配置文件中配置相关的信息。


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

    <context:annotation-config/>

    

    <bean id="sessionConfiguration" class="org.springframework.session.data.redis.config.annotation.web.http.RedisHttpSessionConfiguration">
        
        <property name="maxInactiveIntervalInSeconds" value="1800">property>
    bean>
    <bean class="org.springframework.data.redis.connection.jedis.JedisConnectionFactory">
        <property name="hostName" value="xxx.xx.xxx.xx">property>
        <property name="port" value="6379">property>
    bean>
beans>

注意事项:如上的配置需要开启对应的redis服务。有关redis的学习,网上教材很多,在这里不加赘述。


个人理解:由于spring-session 只是将原生的session以指定的方式进行存储,至于session的操作,它没有什么修改,无侵入,装饰者模式。

你可能感兴趣的:(java)