第十九周作业

1.描述tomcat的架构

tomcat服务器是一种Servlet/jsp容器,更实质性的说是Servlet容器,因为jsp最终还是被编译成servlet来执行的。而对于servlet来说,其最长见的用途是扩展java web服务器功能,为来自web客户的请求提供服务。它完全运行在java虚拟机上。由于它的运行在服务器端,因此他的运行不依赖于浏览器。

tomcat作为servlet容器,负责处理客户请求,把请求传给servlet并把结果返回给客户。servlet容器与servlet之间的接口是由java servlet api定义的,在此api中定义了servlet的各种方法,这些方法在servlet生命周期的不容阶段被servlet容器调用,servlet api还定义了servlet容器传递给servlet的对象类,如请求对象ServletRequest和相应对象ServletResponse。

tomcat服务器是由一系列可配置的组件构成,其中核心组件是Catalina Servlet容器,它是所有其他tomcat组件的顶层容器。tomcat的组件可以在conf/server.xml文件当中进行配置,每个tomcat组件在server.xml文件中进行配置,每个tomcat组件在server.xml文件中对应一种配置元素。

2.详细解释Tomcat的配置文件及配置文件中的参数所代表的含义。

/bin:脚本、批处理,jar文件等启动tomcat文件

/conf:存放tomcat服务器全局配置文件

server.xml: 核心配置文件;

web.xml: 默认部署应用描述符;部署,将一个web应用程序所依赖到的类装进JVM;

context.xml:默认为上下文提供配置文件;

 tomcat-users.xml:为用户认证文件,Tomcat启动后会将这个文件读进内存中完成账号和密码的检测认证,所以这个文件的安全性很重要;

   catalina.policy来定义Tomcat自身的安全和资源授权策略,如定义通过互联网访问时,哪些资源用户可以访问哪些资源用户不能访问;哪些资源能被装载,哪些资源不能被装载等等

   catalina.properties:定义应用程序自身属性;如所使用的内存大小,所使用的字符串缓冲池的大小,你的server loader加载器是什么,等等

   logging.properties:用来定义日志级别,以及日志文件路径

/lib:库文件路径;

/logs:日志目录;

/temp:临时目录;

/webapps:Tomcat的主要Web发布目录,默认情况下把Web应用文件放于此目录

/work:存放JSP编译后产生的class文件

server.xml文件参数详解:

<Server> 

       <Listener /> 

      <GlobaNamingResources> 

      </GlobaNamingResources> 

      <Service> 

            <Connector /> 

            <Engine> 

                <Logger /> 

                <Realm /> 

                     <host> 

                             <Logger /> 

                             <Context /> 

                     </host> 

           </Engine> 

     </Service> 

</Server>

<\Server>元素

它代表整个容器,是Tomcat实例的顶层元素.由org.apache.catalina.Server接口来定义.它包含一个元素.并且它不能做为任何元素的子元素.

<\Connector>元素

由Connector接口定义.元素代表与客户程序实际交互的给件,它负责接收客户请求,以及向客户返回响应结果.

<\Engine>元素

每个Service元素只能有一个Engine元素.处理在同一个中所有元素接收到的客户请求.由org.apahce.catalina.Engine接口定义.

<\Host>元素

它由Host接口定义.一个Engine元素可以包含多个元素.每个的元素定义了一个虚拟主机.它包含了一个或多个Web应用.

<\Context>元素

它由Context接口定义.是使用最频繁的元素.每个可以包含多个元素.每个web应用有唯一的一个相对应的Context代表web应用自身.servlet容器为第一个web应用创建一个

<Server port=”8005″ shutdown=”SHUTDOWN”>  tomcat管理接口;负责监听关闭tomcat的请求

<Listener className=”org.apache.catalina.core.AprLifecycleListener” SSLEngine=”on” />  监听组件;用于集群调试

<GlobalNamingResources>  全局命名资源,定义了用户认证

<Engine name=”Catalina” defaultHost=”localhost”>  引擎名及默认主机

<Realm className=”org.apache.catalina.realm.LockOutRealm”>  定义用户访问的密码;默认没定义用户密码,所以都能访问;

<Valve className=”org.apache.catalina.valves.AccessLogValve” directory=”logs” …… />   定义访问日志


3.配置apache通过mod_proxy模块与tomcat连接的详细过程

apache服务器:192.168.31.23

Tomcat1服务器:192.168.31.233

Tomcat2服务器:192.168.31.26

一、tomcat服务器先安装tomcat 、jdk并配置环境变量

tar -zxvf jdk-8u20-linux-x64.tar.gz -C /usr/local/     解压jdk包

cd /usr/local

ln -sv  jdk1.8.0_20    jdk

vim /etc/profile.d/java.sh   配置java环境变量

JAVA_HOME=/usr/local/jdk
export PATH=$PATH:$JAVA_HOME/bin

source  /etc/profile.d/java.sh  读取环境变量


tar -zxvf apache-tomcat-7.0.56.tar.gz  -C /usr/local/

cd  /usr/local

ln -sv apache-tomcat-7.0.56/ tomcat 

vim /etc/profile.d/catalina.sh 

CATALINA_HOME=/usr/local/tomcat
export PATH=$PATH:$CATALINA_HOME/bin

source /etc/profile.d/catalina.sh 

二、启动tomcat,并访问默认网站

catalina.sh start

ss  -tnl    看8080端口 是否起来

第十九周作业


三、安装并配置apache反向代理服务

yum  -y install httpd

vim /etc/httpd/conf/httpd.conf

# DocumentRoot “/var/www/html”   注释掉默认网页存放位置

在conf.d目录下新建虚拟主机

vim /etc/httpd/conf.d/http-proxy.conf 

<VirtualHost  *:80>

  ProxyVia On

  ProxyPreserveHost  On

  ProxyRequests Off
  ProxyPass  /  http://192.168.31.233:8080/
  ProxyPassReverse / http://192.168.31.233:8080/
  <Proxy *>
    Require all granted
  </Proxy>
  <Location / >
     Require all granted
  </Location>
</VirtualHost>

四、重启apache 访问测试成功

systemctl restart httpd.service

第十九周作业


4.配置基于mod_jk的负载均衡

mod_jk是基于AJP协议的;通过mod_jk模块与tomcat连接;需要额外的软件包进行编译

一、apache服务器安装tomcat连接器 <apxs基于httpd-devel包>

yum -y install httpd-devel

tomcat-connectors-1.2.42-src.tar.gz

tar -zxvf  tomcat-connectors-1.2.42-src.tar.gz

cd  /root/tomcat-connectors-1.2.42-src/native

./configure –with-apxs=/usr/bin/apxs  

make && make install  

二、为了区分两个tomcat网页内容,修改tomcat的配置,并增加jvmRoute

tomcat1:

vim /usr/local/tomcat/conf/server.xml

 <Engine name=”Catalina” defaultHost=”localhost” jvmRoute=”TomcatA”>

<Host name=”localhost”  appBase=”/data/webapps”     
            unpackWARs=”true” autoDeploy=”true”>
 <Context path=”” docBase=”myapp” reloadable=”true” />

tomcat2:

vim /usr/local/tomcat/conf/server.xml

 <Engine name=”Catalina” defaultHost=”localhost” jvmRoute=”TomcatB”>

<Host name=”localhost”  appBase=”/data/webapps”     
            unpackWARs=”true” autoDeploy=”true”>
 <Context path=”” docBase=”myapp” reloadable=”true” />


分别在两个tomcat服务器上创建目录及index.jsp文件

mkdir  /data/webapps/myapp/{classes,lib,WEB-INF,META-INF}

tomcat1:

vim  /data/webapps/myapp/index.jsp

<%@ page language=”java” %>
<html>
 <head><title>TomcatA</title></head>
 <body>
  <h1><font color=”red”>TomcatA </h1>
  <table align=”centre” border=”1″>
   <tr>
    <td>Session ID</td>
  <% session.setAttribute(“abc”,”abc”); %>
    <td><%= session.getId() %></td>
   </tr>
   <tr>
    <td>Created on</td>
    <td><%= session.getCreationTime() %></td>
   </tr>
  </table>
 </body>
</html>
tomcat2:

vim  /data/webapps/myapp/index.jsp

<%@ page language=”java” %>
<html> 
 <head><title>TomcatB</title></head> 
 <body> 
  <h1><font color=”blue”>TomcatB </h1> 
  <table align=”centre” border=”1″> 
   <tr> 
    <td>Session ID</td> 
  <% session.setAttribute(“abc”,”abc”); %> 
    <td><%= session.getId() %></td> 
   </tr> 
   <tr> 
    <td>Created on</td> 
    <td><%= session.getCreationTime() %></td> 
   </tr> 
  </table> 
 </body> 
</html>

三、启动tomcat并访问测试

省略………………………………..


四、配置mod_jk模块实现负载均衡

 vim /etc/httpd/conf/httpd.conf 

# DocumentRoot “/var/www/html”  注释

配置虚拟主机

vim /etc/httpd/conf.d/httpd-jk.conf 

LoadModule jk_module modules/mod_jk.so                                加载mod_jk模块
JkWorkersFile /etc/httpd/conf.d/workers.properties                配置文件位置
JkLogFile logs/mod_jk.log                                                              日志
JkLogLevel debug                                                                            日志级别
JkMount /* lbcluster                                                                       负载均衡器名称
JkMount /jkstatus/ stat1                                                               状态信息

编辑workers.properties配置文件

 vim /etc/httpd/conf.d/workers.properties 

worker.list = lbcluster,stat1
worker.TomcatA.type = ajp13
worker.TomcatA.port = 8009
worker.TomcatA.host = 192.168.31.233
worker.TomcatA.lbfactor = 1
worker.TomcatB.type = ajp13
worker.TomcatB.port = 8009
worker.TomcatB.host = 192.168.31.26
worker.TomcatB.lbfactor = 1
worker.lbcluster.type = lb
worker.lbcluster.sticky_session = 0
worker.lbcluster.balance_workers = TomcatA, TomcatB
worker.stat1.type = status

五、重启apache,并测试

httpd -t

systemctl reload httpd.service

第十九周作业

第十九周作业


5、配置tomcat集群,能够实现用户的session会话保持

DeltaManager实现

原理:是将会话信息同步给集群中其它节点,实现会话复制;

(1).修改tomcat1下的server.xml配置文件

在Engine组件内增加下面这一段

<Cluster className=”org.apache.catalina.ha.tcp.SimpleTcpCluster”channelSendOptions=”8″>
<Manager className=”org.apache.catalina.ha.session.DeltaManager” 
expireSessionsOnShutdown=”false” 
notifyListenersOnReplication=”true”/> 
<Channel className=”org.apache.catalina.tribes.group.GroupChannel”> 
<Membership className=”org.apache.catalina.tribes.membership.McastService” 
address=”228.0.0.4“port=”45564″frequency=”500″dropTime=”3000″/> 
<Receiver className=”org.apache.catalina.tribes.transport.nio.NioReceiver” 
address=”192.168.31.233“port=”4000″autoBind=”100″selectorTimeout=”5000″maxThreads=”6″/> 
<Sender className=”org.apache.catalina.tribes.transport.ReplicationTransmitter”> 
<Transport className=”org.apache.catalina.tribes.transport.nio.PooledParallelSender”/> 
</Sender> 
<Interceptor className=”org.apache.catalina.tribes.group.interceptors.TcpFailureDetector”/> 
<Interceptor className=”org.apache.catalina.tribes.group.interceptors.MessageDispatch15Interceptor”/> 
</Channel> 
<Valve className=”org.apache.catalina.ha.tcp.ReplicationValve”filter=”/”/> 
<Valve className=”org.apache.catalina.ha.session.JvmRouteBinderValve”/> 
<Deployer className=”org.apache.catalina.ha.deploy.FarmWarDeployer”tempDir=”/tmp/war-temp/” 
deployDir=”/tmp/war-deploy/”watchDir=”/tmp/war-listen/”watchEnabled=”false”/> 
<ClusterListener className=”org.apache.catalina.ha.session.JvmRouteSessionIDBinderListener”/> 
<ClusterListener className=”org.apache.catalina.ha.session.ClusterSessionListener”/> 
</Cluster>


修改tomcat2下的server.xml

<Cluster className=”org.apache.catalina.ha.tcp.SimpleTcpCluster”channelSendOptions=”8″>
<Manager className=”org.apache.catalina.ha.session.DeltaManager” 
expireSessionsOnShutdown=”false” 
notifyListenersOnReplication=”true”/> 
<Channel className=”org.apache.catalina.tribes.group.GroupChannel”> 
<Membership className=”org.apache.catalina.tribes.membership.McastService” 
address=”228.0.0.4“port=”45564″frequency=”500″dropTime=”3000″/> 
<Receiver className=”org.apache.catalina.tribes.transport.nio.NioReceiver” 
address=”192.168.31.26“port=”4000″autoBind=”100″selectorTimeout=”5000″maxThreads=”6″/> 
<Sender className=”org.apache.catalina.tribes.transport.ReplicationTransmitter”> 
<Transport className=”org.apache.catalina.tribes.transport.nio.PooledParallelSender”/> 
</Sender> 
<Interceptor className=”org.apache.catalina.tribes.group.interceptors.TcpFailureDetector”/> 
<Interceptor className=”org.apache.catalina.tribes.group.interceptors.MessageDispatch15Interceptor”/> 
</Channel> 
<Valve className=”org.apache.catalina.ha.tcp.ReplicationValve”filter=”/”/> 
<Valve className=”org.apache.catalina.ha.session.JvmRouteBinderValve”/> 
<Deployer className=”org.apache.catalina.ha.deploy.FarmWarDeployer”tempDir=”/tmp/war-temp/” 
deployDir=”/tmp/war-deploy/”watchDir=”/tmp/war-listen/”watchEnabled=”false”/> 
<ClusterListener className=”org.apache.catalina.ha.session.JvmRouteSessionIDBinderListener”/> 
<ClusterListener className=”org.apache.catalina.ha.session.ClusterSessionListener”/> 

</Cluster>

(2).此外,所有启用集群功能的web应用程序,其web.xml中都须添加<distributable/>才能实现集群功能。如果某web应用程序没有自己的web.xml,也可以通过复制默认的web.xml至其WEB-INF目录中     Tomcat1  Tomcat2 都有添加

cp /usr/local/tomcat/conf/web.xml  /data/webapps/myapp/WEB-INF/

vim /data/webapps/myapp/WEB-INF/web.xml

增加一行<distributable/>

第十九周作业


3).重启tomcat,并测试会话绑定

catalina.sh  configtest

catalina.sh  stop|start









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

(0)
N27_VicentN27_Vicent
上一篇 2017-07-10 21:05
下一篇 2017-07-11 08:10

相关推荐

  • linux下解压命令大全

    .tar  解包:tar xvf FileName.tar 打包:tar cvf FileName.tar DirName (注:tar是打包,不是压缩!) ——————————————— .gz 解压1:gunzip FileName.gz 解压2:gzip -d FileName.gz 压缩:gzip FileName .tar.gz 和 .t…

    Linux干货 2017-07-11
  • N26-第一周博客作业

    1.描述计算机的组成及其功能 完整的计算机系统由硬件和软件两部分组成。 现在大部分的计算机为冯诺依曼体系,主要有五个组成部分:运算器、控制器、存储器、输入设备、输出设备,以下为详细描述。(计算机的CPU由运算器、控制器和一二三层缓存等构成) 运算器:对数据进行算术运算和逻辑运算(对数据进行加工处理) 控制器:分析指令,控制协调输入、输出操作对内存的访问。 存…

    Linux干货 2017-01-02
  • N26-第一周作业

    1.    计算机由以下几个部分组成:         a. CPU:中央处理器;主要由运算器和控制器组成            …

    Linux干货 2017-01-07
  • LVS(Linux Virtual Server)学习笔记

    LVS(Linux Virtual Server)学习笔记 此文主要对lvs负载均衡学习的总结,一为记录,二为巩固。主要介绍:1、lvs基础;2、lvs的配置;3、lvs的实现 前提:负载均衡(LB Cluster)     负载均衡实现方法有两种:硬件实现和软件实现;    &…

    Linux干货 2017-02-13
  • linux 系统启动流程

    假设以个人架设的linux主机为例:当你按下电源键之后,计算机硬件会主动读取BIOS来加载硬件信息及进行硬件系统的自我测试,之后系统会主动读取系统第一个可启动的设备,此时就可以读入引导装载程序了。 引导程序可以指定使用哪个内核文件来启动,并实际加载内核到内存中解压缩与执行,此时内核就能够开始在内存内活动,并检测所有硬件信息,与加载适当的驱动程序来使这部主机开…

    Linux干货 2016-09-12
  • varnish 缓存服务器配置与使用

    varnish 缓存服务器配置与使用 一、cache 1.缓存为什么会存在? 一个快的设备要想和慢的设备交互,只有一种办法就是让快的设备工作在慢的设备的频段上!这样的话就浪费了,我们可以在两者之间加上一个加速器,这个加速器就叫做缓存! CPU要读取一个数据时,首先从Cache中查找,如果找到就立即读取并送给CPU处理;如果没有找到,就用相对慢的速度从内存中读…

    2016-11-13

评论列表(1条)

  • 马哥教育
    马哥教育 2017-07-22 21:25

    内容翔实,可以看的出有很认真在做,很赞。