码迷,mamicode.com
首页 > 其他好文 > 详细

tomcat服务器相关介绍一

时间:2015-10-28 15:48:29      阅读:295      评论:0      收藏:0      [点我收藏+]

标签:tomcat、httpd、nginx、apache

一、Tomcat是什么

    Tomcat是Apache在符合J2EE的JSP、Servlet标准下开发的一个JSP服务器,tomcat侧重于servlet引擎,如果以standalone方式运行,可以作为web服务器来使用,支持JSP;tomcat是由java语言开发的,需要在java虚拟机上进行工作。


二、Tomcat的常见的组件

服务器:ServerTomcat的一个实例,通常一个JVM只能包含一个Tomcat实例
服务:Service一个服务组件通常包含一个引擎和与此引擎相关联的一个或多个连接器
连接器:Connector负责连接客户端请求至Servlet容器内的Web应用程序;默认端口为http协议的8080;ajp协议的8009;https的8443
引擎:Engine检查每一个请求的HTTP首部信息以辨别此请求应该发往哪个host或context,并将请求处理后的结果返回的相应的客户端
虚拟主机:Host类似于apache的虚拟主机
上下文:Context 配置一个Context最主要的是指定Web应用程序的根目录,以便Servlet容器能够将用户请求发往正确的位置


三、Tomcat的配置文件说明

server.xmlTomcat的主配置文件,包含Service, Connector, Engine,Valve, Hosts主组件的相关配置信息;
web.xml遵循Servlet规范标准的配置文件,用于配置servlet
catalina.policyJava相关的安全策略配置文件
catalina.propertiesTomcat内部package的定义及访问相关的控制
tomcat-users.xml

认证时用到的相关角色、用户和密码等信息;

Tomcat自带的manager默认情况下会用到此文件

logging.properties日志记录器相关的配置信息


四、Tomcat简单的操作、基于nginx和apache的反向代理实现

前提:在centos7上安装tomcat软件包;并启动,测试访问!

准备:2台centos7虚拟主机,node1:172.16.116.231 ; node2:172.16.116.232

# yum install -y tomcat tomcat-webapps tomcat-admin-webapps tomcat-docs-webapp
# systemctl start tomcat 
# [root@node1 tomcat]# systemctl start tomcat.service
[root@node1 tomcat]# ss -tanl
State      Recv-Q Send-Q                  Local Address:Port                    Peer Address:Port 
LISTEN     0      128                                 *:22                                 *:*     
LISTEN     0      100                         127.0.0.1:25                                 *:*     
LISTEN     0      1                    ::ffff:127.0.0.1:8005                              :::*     
LISTEN     0      100                                :::8009                              :::*     
LISTEN     0      100                                :::8080                              :::*     
LISTEN     0      128                                :::22                                :::*     
LISTEN     0      100                               ::1:25                                :::*

4.1、部署webapp

        deploy:将webapp的源文件放置于目标目录、配置tomcat服务器能够基于context.xml文件中定义的路径来访问此webapp; 将其特有类通过class loader装载至tomcat;可以自动部署和手动部署,这里介绍手动部署中的热部署,使用Tomcat自带的manager工具

[root@node1 ~] # cd /etc/tomcat
[root@node1 tomcat]# vim tomcat-users.xml 
  <role rolename="manager-gui"/>    
  <role rolename="admin-gui"/>
  <user username="tomcat" password="tomcat" roles="manager-gui,admin-gui"/>
[root@node1 tomcat]# systemctl restart tomcat  
设置完成后,可以使用tomcat用户名和对应的密码访问Server Status|Manager App|Host Manager


4.2、Host定义  

[root@node1 tomcat]# vim server.xml      //编辑server.xml文件
 <Host name="node1" appBase="/web/webapps" autoDeploy="false"> //添加node1虚拟主机
   <Context path="" docBase="" reloadable="true"/>
  <Valve className="org.apache.catalina.valves.AccessLogValve" directory="/web/logs"
   prefix="localhost_access_log." suffix=".txt"    
   pattern="%h %l %u %t &quot;%r&quot; %s %b" />     //定义日志格式
 </Host>

[root@node1 tomcat]# mkdir -pv /web/{logs,webapps}   //提供测试页面
<%@ page language="java" %>
<html>
  <head><title>Tomcat1 on node1</title></head>
  <body>
    <h1><font color="red">Tomcat1.node1.com</font></h1>
    <table align="centre" border="1">
      <tr>
        <td>Session ID</td>
    <% session.setAttribute("node1.com","node1.com"); %>
        <td><%= session.getId() %></td>
      </tr>
      <tr>
        <td>Created on</td>
        <td><%= session.getCreationTime() %></td>
     </tr>
    </table>
  </body>
</html>
~       
windows设置hosts文件: 172.16.116.231 node1

技术分享


4.3、修改默认虚拟主机的方法

# vim /etc/tomcat/server.xml
<Engine name="Catalina" defaultHost="localhost">  //defaultHost设置为默认的host<name>即可


4.4、LNT实现方法(nginx反向代理用户请求至tomcat)

[root@node2 ~]# yum install -y nginx    //在node2上安装nginx
[root@node2 ~]# vim /etc/nginx/nginx.conf   //编辑nginx配置文件,加入下面一句
  location / {
     proxy_pass http://node1:8080/     //将客户端的所有请求都反向代理至node1
        }
        
 //如果想动静分离,静态请求由nginx响应,动态请求由node1响应,需要进行下面的修改即可
  location ~* \.(jsp|do)$ {
    proxy_pass http://node1:8080/      //动静分离 

    }

技术分享

技术分享


4.5、LAT实现方法(apache反向代理用户请求至tomcat)

准备工作;编辑 /etc/httpd/conf/httpd.conf将中心主机的DocumentRoot注释

4.5.1、mod_proxy_http

[root@node2 ~]# cd /etc/httpd/conf.d/
[root@node2 conf.d]# vim mod_proxy_http.conf 
<VirtualHost *:80>
    ServerName node2     //虚拟主机名
    ProxyVia On       //是否在响应头部加入via,即代理的主机名
    ProxyRequests Off    //关闭正向代理
    ProxyPreserveHost On   
   <Proxy *>
     Require all granted        //允许所有主机访问
   </Proxy>
     ProxyPass / http://node1:8080/
        ProxyPassReverse / http://node1:8080/   //ProxyPassReverse作用就是反向代理 
   <Location />
     Require all granted
   </Location>
</VirtualHost>

技术分享


4.5.2、mod_proxy_ajp

AJP(Apache JServ Protocol)是定向包协议。因为性能原因,使用二进制格式来传输可读性文本。WEB服务器通过 TCP连接 和 SERVLET容器 连接

[root@node2 conf.d]# vim mod_proxy_ajp.conf        
<VirtualHost *:80>
    ServerName node2
    ProxyVia On
    ProxyRequests Off
    ProxyPreserveHost On
    <Proxy *>
        Require all granted
    </Proxy>
    ProxyPass / ajp://node1:8009/
    ProxyPassReverse / ajp://node1:8009/  //将协议和端口改为ajp和8009即可
    <Location />
        Require all granted
    </Location>
</VirtualHost>                //测试没问题,就不截图了~~


4.5.3、mod_jk

       mod_jk 简称JK,是Apache服务器的一个可插入模块,用以为Apache提供处理JSP/Servlet的能力。mod_jk实质上是Apache与Tomcat的连接器,并附带提供集群和负载均衡的功能。

      apxs是一个为Apache HTTP服务器编译和安装扩展模块的工具,用于编译一个或多个程序或目标代码文件为动态共享对象,使之可以用由mod_so提供的LoadModule指令在运行时加载到Apache服务器中。

(1) mod_jk:额外编译安装

# yum groupinstall "Development tools" 
# cd tomcat-connectors-1.2.40-src/native
# yum install -y httpd-devel                 
# which apxs           
 /usr/bin/apxs
# ./configure --with-apxs=/usr/bin/apxs  
#make && make install


(2)编辑mod_jk的模板配置文件

[root@node2 conf.d]# vim mod_jk.conf   
LoadModule  jk_module  modules/mod_jk.so              //让httpd加载jk模块
JkWorkersFile  /etc/httpd/conf.d/workers.properties    //jk的worker文件
JkLogFile  logs/mod_jk.log                            //日志文件
#JkLogLevel  debug
JkMount  /*  Tomcat1                
JkMount  /status/  stat1


(3)workers配置文件:workers.properties

[root@node2 conf.d]# vim workers.properties
worker.list=Tomcat1,stat1       
worker.Tomcat1.port=8009
worker.Tomcat1.host=172.16.116.231   
worker.Tomcat1.type=ajp13         //mod_jk只能使用ajp13协议 
worker.Tomcat1.lbfactor=1           //权重
worker.stat1.type = status          //这个页面最好加入用户认证

技术分享


五、tomcat 集群;实现session会话保持的3种方法介绍

5.1、基于session会话绑定实现方法,nginx和apache测试!

     在原来的基础上再加入一台虚拟机做反向代理使用;node3:172.16.116.233 

5.1.1、nginx负载均衡至后端tomcat方法;基于session会话绑定实现

<1> node1: 172.16.116.231        //配置tomcat1;修改并加入虚拟主机node1
# vim /etc/tomcat/server.xml
<Engine name="Catalina" defaultHost="node1"> 
<Host name="node1" appBase="/web/webapps/" autoDeploy="false" >
   <Context path="" docBase="" reloadable="true"/>
  <Valve className="org.apache.catalina.valves.AccessLogValve" directory="/web/logs"
      prefix="localhost_access_log." suffix=".txt"
      pattern="%h %l %u %t &quot;%r&quot; %s %b" />
 </Host>


<2> node2: 172.16.116.232       //配置tomcat2;修改并加入虚拟主机node2,
# vim /etc/tomcat/server.xml
<Engine name="Catalina" defaultHost="node2"> 
<Host name="node2" appBase="/web/webapps/" autoDeploy="false" >
   <Context path="" docBase="" reloadable="true"/>
  <Valve className="org.apache.catalina.valves.AccessLogValve" directory="/web/logs"
     prefix="localhost_access_log." suffix=".txt"
     pattern="%h %l %u %t &quot;%r&quot; %s %b" />
 </Host>
             
<3> node3: 172.16.116.233       //配置nginx负载均衡的反向代理
# vim /etc/nginx/nginx.conf        
 upstream tomcatservs {           //在http段加入upstream上游服务器
        ip_hash ;               //源地址hash,将同一源地址的请求始终定向至某一上游服务器
       server node1:8080;         //达到session会话绑定的目的     
       server node2:8080;
     }
     
 location / {                          //在server段中加入反向代理
       proxy_pass http://tomcatservs/       
    }


5.1.2、apache负载均衡至后端tomcat方法;基于session会话绑定实现

通过apache3种反向代理的方式进行测试 

 apache:tomcat

mod_proxy 

mod_proxy_http 

mod_proxy_balancer

http connector    //http协议连接器

mod_proxy

mod_proxy_ajp

mod_proxy_balancer

ajp connector     //ajp协议连接器
mod_jkajp connector    //ajp协议连接器


▲▲▲httpd负载均衡集群使用到的选项总结▲▲▲

lbfactor表示:后台服务器负载到由Apache发送请求的权值,该值为1到100之间的任何值。

BalancerMember:负载均衡集群中的成员

lbmethod表示:负载载均衡策略。 

lbmethod=byrequests 按照请求次数均衡(默认) 

lbmethod=bytraffic 按照流量均衡 

lbmethod=bybusyness 按照繁忙程度均衡(总是分配给活跃请求数最少的服务器)

ProxyPass表示:所有的test请求都会重定向到balancer://lbcluster1/处理。balancer是内置负载。

ProxyPassReverse表示:反向代理,也就是将所有的请求反向代理到负载均衡后的应用url路径中。

stickysession表示:进行Session复制使用


①mod_proxy_http 、http connector

node1 : 172.16.116.231 
<Engine name="Catalina" defaultHost="node1" jvmRoute="Tomcat1">  //Engine加入jvmRoute标识

node2 : 172.16.116.232
<Engine name="Catalina" defaultHost="node1" jvmRoute="Tomcat2"> //Engine加入jvmRoute标识

node3 : 172.16.116.233
[root@node3 conf.d]# vim mod_proxy_http.conf 

header add Set-Cookie "ROUTEID=.%{BALANCER_WORKER_ROUTE}e; path=/" env=BALANCER_ROUTE_CHANGED
<proxy balancer://lbcluster1>
    BalancerMember http://172.16.116.231:8080 loadfactor=1 route=Tomcat1
    BalancerMember http://172.16.116.232:8080 loadfactor=1 route=Tomcat2
    ProxySet stickysession=ROUTEID               //根据routeid做session绑定
</proxy>

<VirtualHost *:80>
    ServerName node3
    ProxyVia On
    ProxyRequests Off
    ProxyPreserveHost On
    <Proxy *>
        Require all granted
    </Proxy>
    ProxyPass / balancer://lbcluster1/          //注意,要使用balancer
    ProxyPassReverse / balancer://lbcluster1/
    <Location />
        Require all granted
    </Location>
</VirtualHost>

技术分享


mod_proxy_ajp、ajp connector

[root@node3 conf.d]# vim mod_proxy_ajp.conf    //只需修改这个地方,其它不用修改即可实现 
BalancerMember ajp://172.16.116.231:8009 loadfactor=1 route=Tomcat1
BalancerMember ajp://172.16.116.231:8009 loadfactor=1 route=Tomcat1


mod_jk、ajp connector

[root@node3 conf.d]# vim mod_jk.conf
LoadModule jk_module modules/mod_jk.so
JkWorkersFile  /etc/httpd/conf.d/workers.properties     //集群worker相关配置
JkLogFile  logs/mod_jk.log
JkLogLevel  error
JkMount  /*  lbcluster1
JkMount  /status/  stat1

[root@node3 conf.d]# vim workers.properties 
worker.list = lbcluster1,stat1             //worker列表
worker.Tomcat1.type = ajp13        //Tomcat1是node1节点上的运行tomcat的jvm标识
worker.Tomcat1.host = 172.16.116.231      //ip或主机名都可以
worker.Tomcat1.port = 8009
worker.Tomcat1.lbfactor = 1
worker.Tomcat2.type = ajp13        //Tomcat2是node2节点上的运行tomcat的jvm标识
worker.Tomcat2.host = 172.16.116.232     //ip或主机名都可以    
worker.Tomcat2.port = 8009
worker.Tomcat2.lbfactor = 1             //权重
worker.lbcluster1.type = lb
worker.lbcluster1.sticky_session = 0    //是否绑定session会话;0为不绑定,1为绑定
worker.lbcluster1.balance_workers = Tomcat1, Tomcat2   //lbcluster1集群成员
worker.stat1.type = status


5.2、基于session 集群的方法,也就是session共享

session manager:会话管理器;常用的管理器有4种

StandardManager

标准会话管理器

PersistentManager

持久会话管理器

FileStore :文件存储,可以存在nfs服务器上

JDBC :基于jdbc存储在后端的关系型数据库中,如mysql

DeltaManager

 Manager用来在节点间拷贝Session,默认使用DeltaManager

DeltaManager采用的一种all-to-all的工作方式,即集群中的节点会把

Session数据向所有其他节点拷贝,而不管其他节点是否部署了当前应用

BackupManager

备用会话管理器

当集群中的节点数量很多并且部署着不同应用时,可以使用

BackupManager,BackManager仅向部署了当前应用的节点拷贝Session

 这里主要介绍DeltaManager的实现方法:

前端的node3负载均衡的相关配置不需要改变,使用上述3种方式都可以,只需要在tomcat节点上修改;node1:172.16.116.231 ; node2:172.16.116.232 需要做如下的修改 ;根据官方文档实现

http://tomcat.apache.org/tomcat-7.0-doc/cluster-howto.html

[root@node2 ~]# mkdir /web/webapps/ROOT/{classes,lib,META-INF,WEB-INF} -pv
[root@node2 ~]# cp /usr/share/tomcat/webapps/ROOT/WEB-INF/web.xml /web/webapps/ROOT/WEB-INF/
<Host name="node2" appBase="/web/webapps" autoDeploy="false">
        <Context path="" docBase="ROOT" reloadable="true"/>
   <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.16.7"
                     port="45564"
                     frequency="500"
                     dropTime="3000"/>
   <Receiver className="org.apache.catalina.tribes.transport.nio.NioReceiver"
                     address="172.16.116.232"
                      port="4000"
                       autoBind="100"
                       selectorTimeout="5000"
        </Sender>
        </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.ClusterSessionListener"/>
 </Cluster>
 <Valve className="org.apache.catalina.valves.AccessLogValve" directory="/web/logs"
               prefix="localhost_access_log." suffix=".txt"
               pattern="%h %l %u %t &quot;%r&quot; %s %b" />
      </Host>

[root@node2 ~]# vim /web/webapps/ROOT/WEB-INF/web.xml
     <distributable/>

技术分享

技术分享

▲▲▲特别要说明的是▲▲▲

tomcat集群中的session管理,主要有两种方式:

1).粘性session

表示从同一客户端发来的请求都将有集群中的同一个tomcat进行处理。配置方式是在上面的workers.properties文件中

Xml代码  

  1. worker.lbcontroller.sticky_session=1  

粘性session的好处在不会在不同的tomcat上来回跳动处理请求,但是坏处是如果处理该session的tomcat崩溃,那么之后的请求将由其他tomcat处理,原有session失效而重新新建一个新的session,这样如果继续从session取值,会抛出nullpointer的访问异常。

2).session复制

session复制是指tomcat彼此之间通过组播方式将session发到各个tomcat实例上,如果其中一个访问出错,则另外tomcat仍然具有有效的session内容,从而能正常接管其session。坏处是当tomcat实例很多,或者用户在session中有大量操作时,组播发送的信息量十分惊人。session复制配置则是在发布的web应用程序中的web.xml中添加

Xml代码  

  1. <distributable/>  


以上就是这次讲到的内容,下次再介绍session服务器的实现方法,基于msm的实现过程! 谢谢O(∩_∩)O~~ 


本文出自 “bengbengtu” 博客,请务必保留此出处http://bengbengtu.blog.51cto.com/9505633/1707207

tomcat服务器相关介绍一

标签:tomcat、httpd、nginx、apache

原文地址:http://bengbengtu.blog.51cto.com/9505633/1707207

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!