Apache通过mod_proxy模块连接Tomcat并使用Memcached+MSM做Tomcat会话保持

一 实验目的

本实验使用Apache的mod_proxy模块连接Tomcat, Nginx在前端做负载均衡,并使用Memcahced+MSM的方式保持Tomcat的会话,实现会话共享。

二 实验拓扑

说明:为测试方便,Memcached与Tomcat安装在同一机器中,正式环境应该安装在不同机器中。

1.png

三 实验环境

主机 IP 安装组件
node1 192.168.237.132 nginx
node2 192.168.237.129 httpd+tomcat+memcached
node3 192.168.237.130 httpd+tomcat+memcached

四 实验步骤

1 在node2和node3上安装tomcat

#安装Java环境
rpm -ivh jdk-7-linux-x64.rpm   #首先应下载jdk安装包
注:如系统已安装了openjdk的包,应先卸载。例:yum remove java-1.7.0-openjdk*
#设置Java的环境变量
vim /etc/profile.d/java.sh
export JAVA_HOME=/usr/java/latest
export PATH=$PATH:$JAVA_HOME:/bin
source /etc/profile.d/java.sh
#解压tomcat包
tar xvzf apache-tomcat-7.0.73.tar.gz -C /usr/local/
ln -sv /usr/local/apache-tomcat-7.0.73 /usr/local/tomcat
#设置tomcat环境变量
vim /etc/profile.d/tomcat.sh
export CATALINA_HOME=/usr/local/tomcat
export PATH=$PATH:$CATALINA_HOME/bin
source /etc/profile.d/tomcat.sh
#启动tomcat
catalina.sh start

测试访问,浏览器中输入192.168.237.129:8080, 如下图所示:

2.png

2 在node2和node3上安装httpd并配置通过ajp协议代理至tomcat

#安装httpd
yum install httpd
#配置httpd使得通过ajp协议代理至tomcat
vim /etc/httpd/conf/httpd.conf
#DocumentRoot "/var/www/html"    #注释掉主配置文件中的根目录
#配置虚拟主机
vim /etc/httpd/conf.d/tomcat.conf
<VirtualHost *:80>
  servername a.com
  ProxyRequests Off
  ProxyVia On
  ProxyPreserveHost On
  <Proxy *>
    Require all granted
  </Proxy>
  ProxyPass / ajp://127.0.0.1:8009/
  ProxyPassReverse / ajp://127.0.0.1:8009
  <Location />
    Require all granted
  </Location>
</VirtualHost>

测试访问,浏览器中输入192.168.237.129, 如下图所示:

3.png

3 在node2和node3上配置安装Memcahed+MSM

#安装memcached
yum install memcached
#启动memcached
systemctl start memcached
#修改tomcat配置文件
vim /usr/local/tomcat/conf/server.conf   #在<Host>下添加如下内容
<Context path="/test" docBase="/usr/local/tomcat/webapps/test" reloadable="true">
 <Manager className="de.javakaffee.web.msm.MemcachedBackupSessionManager"
          memcachedNodes="n1:192.168.237.129:11211,n2:192.168.237.130:11211"
          failoverNodes="n1"
          requestUriIgnorePattern=".*\.(ico|png|gif|jpg|css|js)$"
          transcoderFactoryClass="de.javakaffee.web.msm.serializer.javolution.JavolutionTranscoderFactory"
 />
</Context>
#创建jsp会话测试文件
mkdir -pv /usr/local/tomcat/webapps/test/{classes,lib,META-INF,WEB-INF}
vim / /usr/local/tomcat/webapps/test/index.jsp
<%@ page language="java" %>
<html>
  <head><title>TomcatA</title></head>
  <body>
    <h1><font color="red">TomcatA.magedu.com</font></h1>
    <table align="centre" border="1">
      <tr>
        <td>Session ID</td>
    <% session.setAttribute("magedu.com","magedu.com"); %>
        <td><%= session.getId() %></td>
      </tr>
      <tr>
        <td>Created on</td>
        <td><%= session.getCreationTime() %></td>
      </tr>
    </table>
  </body>
</html>
注:在node3上把TomcatA变成TomcatB, red变成blue即可

测试访问,浏览器中输入192.168.237.129/test和192.168.237.130/test, 应如下图所示:

4.png5.png

#下载MSM的类库文件并放到/usr/local/tomcat/lib中
[root@node2 ~]# mv javolution-5.4.3.1.jar memcached-session-manager-1.8.3.jar memcached-session-manager-tc7-1.8.3.jar msm-javolution-serializer-1.8.3.jar spymemcached-2.11.1.jar /usr/local/tomcat/lib/
#重新启动tomcat
catalina.sh stop
catalina.sh start

4 在node1上配置Nginx并配置负载均衡

#安装nginx
yum install nginx
#配置负载均衡
upstream tomcat_server {
    server 192.168.237.129;
    server 192.168.237.130;
}

server {
    listen       80;
    server_name 192.168.237.132;

location / {
    root /usr/local/tomcat/webapps;
    proxy_pass http://tomcat_server;
}

测试访问,浏览器中输入192.168.237.132/test, 查看session是否变化。

6.png7.png

可以看出已经实现了session保持。

原创文章,作者:N25_zzc,如若转载,请注明出处:http://www.178linux.com/66780

(0)
N25_zzcN25_zzc
上一篇 2017-01-17 15:07
下一篇 2017-01-17 20:57

相关推荐

  • nl命令使用解析

    nl    命令功用: nl – number lines of files 显示文件内容,并列出行号   命令样式: nl [OPTION]… [FILE]…   命令选项: -b:正文行号,参数为样式style -n:行号格式,参数为格式format -w:设定行号所占位数,参数为…

    Linux干货 2016-10-20
  • OpenSSL

    OpenSSL由三部分组成:             libencrypto库             libssl库 …

    Linux干货 2017-05-30
  • 将两个局域网用openvpn连接起来

    考虑到我们做集群的时候需要用到可能有20台机器,可能我的要求跟别人的不一样的,我需要做20台左右的集群,不仅仅是会,而且需要非常熟练的搭建,最后通过脚步一键自动化部署安装。 目前我有两台电脑,一台可以运行7台,另一台可以运行12台左右,刚好可以满足的我的要求,但是我两台电脑都是设置的nat模式的网络,为什么我非要配置nat模式呢,根据集群架构思想,为了保证架…

    Linux干货 2017-05-01
  • linux中bash的基础特性和基本文件管理命令

    linux的文件管理类命令 linux系统下的涉及到目录管理命令,主要有 mkdir,rmdir linux系统下也会用到许多文件查看类命令,包括cat,tac,head,tail,more,less等 linux系统下涉及的文件管理类命令主要有cp,mv,rm 本节我们主要说明文件管理类命令的使用方法。 cp命令的使用方法 首先,cp这个命令的作用是可以复…

    Linux干货 2016-09-26
  • Linux的终端类型

    一、了解终端   在早期的年代,主机不是很多,都是一系列的大型主机,简单来说就是用户很多,但主机很少,不可能做到人手一台,但可以在主机上连接一个分屏器,在分屏器上可以连接鼠标键盘以及显示器,这些东西是没有计算能力的,仅仅担任输入和输出的工作,运算和处理都是由主机来完成的。   简单来说终端是用户与主机交互,是必然用到的…

    Linux干货 2016-10-14
  • 重定向、管道——Linux基本命令(9)

    1.     输出重定向 Linux默认输入是键盘,输出是显示器。可以用重定向来改变这些设置。比如用wc命令的时候本来是要手动输入一篇文字来计算字符数的,可以直接把一个已经写好的文件用‘<’指向这条命令,就直接可以统计这个文件的字符数等了。   STDOUT(标准输出)和STDERR(标准错误)可以被重…

    2017-07-20

评论列表(1条)

  • 马哥教育
    马哥教育 2017-04-10 16:03

    总结的很好,请继续保持~~~加油!!