设为首页 收藏本站
查看: 585|回复: 0

[经验分享] tomcat msm

[复制链接]

尚未签到

发表于 2018-12-1 13:42:00 | 显示全部楼层 |阅读模式
准备工作
  准备三台虚拟机, 均为CentOS-7-x86_64最小化安装, iptables与SELinux均处于关闭状态, 配置好yum源(base和epel). 做好快照, 以便每次实验后快速恢复.
  

HostA
OS: CentOS-7-x86_64
hostname: 80e54d87.twoyang.com
eno16777736: 172.18.71.101/16
gateway: 172.18.0.1
HostB
OS: CentOS-7-x86_64
hostname: b9cf468b.twoyang.com
eno16777736: 172.18.71.102/16
gateway: 172.18.0.1
HostC
OS: CentOS-7-x86_64
hostname: 1f5fafa6.twoyang.com
eno16777736: 172.18.71.103/16
gateway: 172.18.0.1  先不管Memcached和MSM, 按照nginx负载均衡tomcat部署好集群.
集群初始化
  建立主机信任, 时间同步, 统一增加yum源. 这一步其实在哪个节点上做都可以, 我这里选择HostA.
# 写了个脚本来做这个事情
[root@80e54d87 ~]# wget https://raw.githubusercontent.com/wqiang0917/LearnInMagedu/master/shell/sshtrust.sh
# 将集群中所有节点IP地址(包括本机)都加入这个主机列表数组
[root@80e54d87 ~]# vim sshtrust.sh
HOSTS=("172.18.71.101" "172.18.71.102" "172.18.71.103")
# 分发密钥, 建立主机信任.
[root@80e54d87 ~]# bash sshtrust.sh --key
# 同步时间
[root@80e54d87 ~]# bash sshtrust.sh "ntpdate 172.18.0.1"
[root@80e54d87 ~]# bash sshtrust.sh "hwclock --systohc"
[root@80e54d87 ~]# bash sshtrust.sh date
Tue Jun  7 21:54:22 CST 2016
Tue Jun  7 21:54:22 CST 2016
Tue Jun  7 21:54:22 CST 2016HostA
# 安装`OpenJDK`和`Tomcat`
[root@80e54d87 ~]# yum install -y java-1.7.0-openjdk java-1.7.0-openjdk-devel tomcat tomcat-lib tomcat-admin-webapps tomcat-webapps
[root@80e54d87 ~]# echo "export JAVA_HOME=/usr" > /etc/profile.d/java.sh
[root@80e54d87 ~]# exec bash
# 创建sessapp应用, 并提供session测试主页.
[root@80e54d87 ~]# mkdir -p /var/lib/tomcat/webapps/sessapp/{classes,lib,WEB-INF,META-INF}
[root@80e54d87 ~]# cat  /var/lib/tomcat/webapps/sessapp/index.jsp


  TomcatA
  
    TomcatA.magedu.com
   
      
        Session ID
   
        
      
      
        Created on
        
     
   
  

EOF
# 启动服务, 并检查监听端口.
[root@80e54d87 ~]# systemctl start tomcat.service
[root@80e54d87 ~]# ss -tnl | grep "\(4000\|8009\|8080\)"
LISTEN     0      100         :::8009                    :::*                  
LISTEN     0      100         :::8080                    :::*                  
LISTEN     0      50        ::ffff:172.18.71.101:4000                    :::*HostB
# 安装`OpenJDK`和`Tomcat`
[root@b9cf468b ~]# yum install -y java-1.7.0-openjdk java-1.7.0-openjdk-devel tomcat tomcat-lib tomcat-admin-webapps tomcat-webapps
[root@b9cf468b ~]# echo "export JAVA_HOME=/usr" > /etc/profile.d/java.sh
[root@b9cf468b ~]# exec bash
[root@b9cf468b ~]# mkdir -p /var/lib/tomcat/webapps/sessapp/{classes,lib,WEB-INF,META-INF}
# 创建sessapp应用, 并提供session测试主页.
[root@b9cf468b ~]# cat  /var/lib/tomcat/webapps/sessapp/index.jsp


  TomcatB
  
    TomcatB.magedu.com
   
      
        Session ID
   
        
      
      
        Created on
        
     
   
  

EOF
# 启动服务, 并检查监听端口.
[root@b9cf468b ~]# systemctl start tomcat.service
[root@b9cf468b ~]# ss -tnl | grep "\(4000\|8009\|8080\)"
LISTEN     0      100         :::8009                    :::*                  
LISTEN     0      100         :::8080                    :::*                  
LISTEN     0      50        ::ffff:172.18.71.101:4000                    :::*HostC
# 首先测试使用curl直接访问HostA与HostB的sessapp.
[root@1f5fafa6 ~]# curl http://172.18.71.101:8080/sessapp/

  TomcatA
  
    TomcatA.magedu.com
   
      
        Session ID
        4D5C16AFE6FDA767E506729B0781A0B7
      
      
        Created on
        1465284908776
     
   
  

[root@1f5fafa6 ~]# curl http://172.18.71.102:8080/sessapp/

  TomcatB
  
    TomcatB.magedu.com
   
      
        Session ID
        185E2BDA227CB166CA75B7FDC1A07BE4
      
      
        Created on
        1465284924384
     
   
  

# 安装nginx作为前端调度器反代.
[root@1f5fafa6 ~]# yum install -y nginx
[root@1f5fafa6 ~]# vim /etc/nginx/nginx.conf
    ...
    upstream tcsrvs {
        server 172.18.71.101:8080 weight=1;
        server 172.18.71.102:8080 weight=2;
    }
    server {
        ...
        location / {
            proxy_pass http://tcsrvs;
        }
    }
    ...
# 测试语法
[root@1f5fafa6 ~]# nginx -t
nginx: the configuration file /etc/nginx/nginx.conf syntax is ok
nginx: configuration file /etc/nginx/nginx.conf test is successful
# 启动服务
[root@1f5fafa6 ~]# systemctl start nginx.service
[root@1f5fafa6 ~]# ss -tnl | grep 80
LISTEN     0      128          *:80                       *:*                  
LISTEN     0      128         :::80                      :::*  使用浏览器访问http://172.18.71.103/sessapp/, 持续刷新页面. 可以看到通过前端调度器nginx在按照权重轮调后端服务器, 并且SessionID一直在变化. 此时使用Memcached和MSM存储会话.
注意: 不要使用curl来测试, curl不是daemon进程, 执行完就退出了, 没有办法保存会话.

Memcached和MSM
  在HostA和HostB两个后端tomcat主机上均要执行以下操作, 以HostA为例.
# 安装memcached
[root@80e54d87 ~]# yum install -y memcached
[root@80e54d87 ~]# systemctl start memcached.service
[root@80e54d87 ~]# ss -tnl | grep 11211
LISTEN     0      128          *:11211                    *:*                  
LISTEN     0      128         :::11211                   :::*
# 下载MSM的类库放置在tomcat的公共类库目录中
[root@80e54d87 ~]# ls msm/
javolution-5.4.3.1.jar               memcached-session-manager-tc7-1.8.3.jar  spymemcached-2.11.1.jar
memcached-session-manager-1.8.3.jar  msm-javolution-serializer-1.8.3.jar
[root@80e54d87 ~]# cp msm/*.jar /usr/share/java/tomcat/
# 增加配置
[root@80e54d87 ~]# vim /etc/tomcat/server.xml
...

   
      
   

...
# 重启服务
[root@80e54d87 ~]# systemctl restart tomcat.service测试验证
  可以观察到调度器一直在按照权重轮调后端服务器, 但是SessionID一直没有变化. 此时使用的是标识为n2的memcached作为主session server. 说明session可以全局共享.
注意: 不要使用curl来测试, curl不是daemon进程, 执行完就退出了, 没有办法保存会话.

  •   关闭当前作为主session server的HostB上的memcached, 再来刷新页面.
[root@b9cf468b ~]# systemctl stop memcached.service
http://7xltax.com1.z0.glb.clouddn.com/tomcat_msm_2.gif
可以观察到SessionID没有变化, 而session server已经切换到了是标识为n1的memcached. 说明单个session server发生故障, 会话也不会丢失.





运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-642000-1-1.html 上篇帖子: 安装 tomcat 下篇帖子: tomcat的优化
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表