我的日常

登录/注册
您现在的位置:论坛 盖世程序员(我猜到了开头 却没有猜到结局) 运维优化 > Nginx+Tomcat+Memcached 负载均衡实现Session共享
总共48087条微博

动态微博

查看: 2385|回复: 2

Nginx+Tomcat+Memcached 负载均衡实现Session共享

[复制链接]
admin    

1244

主题

544

听众

1万

金钱

管理员

  • TA的每日心情

    2021-2-2 11:21
  • 签到天数: 36 天

    [LV.5]常住居民I

    管理员

    跳转到指定楼层
    楼主
    发表于 2016-01-18 17:59:19 |只看该作者 |正序浏览


    上一次讲到 阿里云linux下Nginx整合Tomcat实现负载均衡集群 只是单纯的实现 负载均衡并没有实现Session的共享。

    一、说明
          我们系统经常要保存用户登录信息,有Cookie和Session机制,Cookie客户端保存用户信息,Session在服务端保存用户信息,如果浏览器不支持Cookie或者用户把Cookie禁掉了,Cookie就用不了,还有不同的浏览器采用不用方式保存Cookie,所以我们采用Session服务端来保存,上一节我们有介绍了Tomcat集群部署,怎么样集群的Tomcat对同个用户请求的都能获取保存在Session的用户信息,采用了Memcached管理Session,Memcached 是一个高性能的分布式内存对象缓存系统,接下来我们介绍Nginx+Tomcat+Memcached实现Session共享。


    二.Tomcat、Nginx、Memcached配置
       第一步:Memcached的安装部署Memcached部署 这查看这篇文章
       第二步: Nginx的安装部署 这查看这篇文章
       第三步:Tomcat和JDK的安装和环境配置 Tomcat和JDK的安装部署 这查看这篇文章

    三.实现
        我们采用Memcached管理Session,主要是memcached-session-manager开源tomcat插件改变Tomcat原始的Session存储机制,将session的存储放到分布式缓存Memcached中,从而实现对Session的共享。

        第一步:修改tomcat1和tomcat2下的conf/context.xml 文件,修改session的存储方式。

    1. <Manager className="de.javakaffee.web.msm.MemcachedBackupSessionManager"   
    2.     memcachedNodes="n1:localhost:12000"   
    3.     requestUriIgnorePattern=".*\.(png|gif|jpg|css|js)$"   
    4.     sessionBackupAsync="false"   
    5.     sessionBackupTimeout="100"   
    6.     transcoderFactoryClass="de.javakaffee.web.msm.serializer.javolution.JavolutionTranscoderFactory"   
    7.     copyCollectionsForSerialization="false" />
    复制代码





    说明:
      1.requestUriIgnorePatter:过滤图片等静态文件去触发Session备份到Memcached。
      2.sessionBackupAsync:指定Session是否应该被异步保存到Memcached中。
      3.backupThreadCount :用来异步保存Session的线程数。
      4.sessionBackupTimeout :默认100毫秒,操作超过时间那么保存失败。




    第二步:要引入memcached-session-manager所需要的jar包


    couchbase-client-1.0.3.jar
    javolution-5.4.3.1.jar
    memcached-2.6.jar
    memcached-session-manager-1.5.1.jar
    memcached-session-manager-tc7-1.5.1.jar
    msm-javolution-serializer-1.5.1.jar
    msm-kryo-serializer-1.5.1.jar
    msm-xstream-serializer-1.5.1.jar
    JAR包下载地址 : http://pan.baidu.com/s/1nuf5l7z

    分别重启 tomcat 和Nginx



    演示地址:http://love.52itstyle.com/love.jsp




    科帮网 1、本主题所有言论和图片纯属会员个人意见,与本社区立场无关
    2、本站所有主题由该帖子作者发表,该帖子作者与科帮网享有帖子相关版权
    3、其他单位或个人使用、转载或引用本文时必须同时征得该帖子作者和科帮网的同意
    4、帖子作者须承担一切因本文发表而直接或间接导致的民事或刑事法律责任
    5、本帖部分内容转载自其它媒体,但并不代表本站赞同其观点和对其真实性负责
    6、如本帖侵犯到任何版权问题,请立即告知本站,本站将及时予与删除并致以最深的歉意
    7、科帮网管理员和版主有权不事先通知发贴者而删除本文


    JAVA爱好者①群:JAVA爱好者① JAVA爱好者②群:JAVA爱好者② JAVA爱好者③ : JAVA爱好者③

    33

    主题

    1

    听众

    409

    金钱

    四袋长老

    该用户从未签到

    板凳
    发表于 2016-11-02 15:28:30 |只看该作者
    看后学习,真心学习,很好,谢谢
    回复

    使用道具 举报

    12

    主题

    3

    听众

    526

    金钱

    四袋长老

    该用户从未签到

    沙发
    发表于 2016-06-23 16:56:11 |只看该作者
    马克一记.......=
    回复

    使用道具 举报

    快速回复
    您需要登录后才可以回帖 登录 | 立即注册

       

    关闭

    站长推荐上一条 /1 下一条

    发布主题 快速回复 返回列表 联系我们 官方QQ群 科帮网手机客户端
    快速回复 返回顶部 返回列表