1 项目图(下图为gif动图):技术及框架 SpringMVC druid redis zookeeper mybatis mysql dubbo

dubbo系列(二) 完整SpringMVC项目整合druid redis zookeeper mybatis dubbo spring-data-redis实现分布式session

2 自定义session管理(下图为gif动图): 在请求参数里带有sessionId,业务方法使用RequestData获取和保存数据,aop实现保存RequestData的session数据到redis中,这种session管理方式适合给接口使用

dubbo系列(二) 完整SpringMVC项目整合druid redis zookeeper mybatis dubbo spring-data-redis实现分布式session

3 数据库连接池druid

dubbo系列(二) 完整SpringMVC项目整合druid redis zookeeper mybatis dubbo spring-data-redis实现分布式session

4 zookeeper配置.gif

dubbo系列(二) 完整SpringMVC项目整合druid redis zookeeper mybatis dubbo spring-data-redis实现分布式session

ps 4.1 java操作zookeeper的入门可以参考这篇博客(https://www.cnblogs.com/shay-zhangjin/tag/zookeeper/)

dubbo系列(二) 完整SpringMVC项目整合druid redis zookeeper mybatis dubbo spring-data-redis实现分布式session

5 事务测试.gif

dubbo系列(二) 完整SpringMVC项目整合druid redis zookeeper mybatis dubbo spring-data-redis实现分布式session

 

6 REST风格 PUT方法测试

dubbo系列(二) 完整SpringMVC项目整合druid redis zookeeper mybatis dubbo spring-data-redis实现分布式session

 

7 dubbo-admin管理后台

这里的配置<dubbo:application name="category"/> 服务提供者和服务消费者应用名可以不一样的,主要用于依赖分析,与服务调用没有关系的。

dubbo系列(二) 完整SpringMVC项目整合druid redis zookeeper mybatis dubbo spring-data-redis实现分布式session

8 使用sping-data-redis实现分布式session最终效果

dubbo系列(二) 完整SpringMVC项目整合druid redis zookeeper mybatis dubbo spring-data-redis实现分布式session

dubbo系列(二) 完整SpringMVC项目整合druid redis zookeeper mybatis dubbo spring-data-redis实现分布式session

8.1 代码

8.1.1 web.xml增加一个filter

<context-param>
        <param-name>contextConfigLocation</param-name>
        <param-value>classpath: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>
        <dispatcher>REQUEST</dispatcher>
        <dispatcher>ERROR</dispatcher>
    </filter-mapping>
    <listener>
        <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
    </listener>
View Code

相关文章: