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

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

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

3 数据库连接池druid

4 zookeeper配置.gif

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

5 事务测试.gif

 

6 REST风格 PUT方法测试

 

7 dubbo-admin管理后台

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

8 使用sping-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

 

8.1.2 Controller

    private  static  final  String KEY ="existAttr";
    @RequestMapping("/springSession")
    @ResponseBody
    public  Map<String,Object>  springSession(HttpSession httpSession,String keyPart, HttpServletRequest request){
        Map<String,Object> resultMap=new HashMap<>();
        resultMap.put(KEY, httpSession.getAttribute(KEY));
        httpSession.setAttribute(KEY,CommonUtil.generatorUUID(null)+keyPart);
        resultMap.put("newAttr",  httpSession.getAttribute(KEY));

        String server=request.getLocalAddr()+":"+request.getLocalPort();
        resultMap.put("server",server);
        return  resultMap;
    }
View Code

8.1.3 spring其他内容配置

    可以参考这篇博客(https://www.cnblogs.com/youzhibing/p/7348337.html)

8.1.4 nginx增加配置

location /dubbostudy-web {
	proxy_pass http://dubbostudy-web;
	proxy_set_header Host $host;
	proxy_set_header X-Real-IP $remote_addr;
	proxy_set_header REMOTE-HOST $remote_addr;
	proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
}


upstream dubbostudy-web{
     server 192.168.10.132:8083 weight=1;
     server 192.168.10.132:8084 weight=1;
}
View Code

 

转载于:https://www.cnblogs.com/LDDXFS/p/9757007.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值