Tomcat整体架构和配置

本文详细介绍了Tomcat的整体架构,包括Server、Service、Connector和Container等组件,以及它们之间的关系。通过实例演示了Tomcat的安装部署、配置虚拟主机、支持SSL加密和集群配置等操作步骤,帮助读者理解Tomcat的工作原理并掌握实际操作技巧。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Tomcat源码分析 -- Tomcat整体架构

Tomcat顶层结构

先上一张图:

上图大概展示了tomcat的结构,下面先简单介绍各个模块:

 

  • Server:服务器的意思,代表整个tomcat服务器,一个tomcat只有一个Server;
  • Service:Server中的一个逻辑功能层, 一个Server可以包含多个Service;
  • Connector:称作连接器,是Service的核心组件之一,一个Service可以有多个Connector,主要是连接客户端请求;
  • Container:Service的另一个核心组件,按照层级有Engine,Host,Context,Wrapper四种,一个Service只有一个Engine,其主要作用是执行业务逻辑;
  • Host:Host的元素定义了一个虚拟主机.它包含了一个或多个Web应用

一个server有多个service,每个service对应多个Connector,多个Connector对应一个前台Engine ,一个Engine对应多个Host,host下对应多个虚拟机。

 

1.安装部署tomcat服务软件。 

1.)安装 jdk 1.8环境软件包

[root@web1 ~]# yum -y install java-1.8.0-openjdk //安装JDK

[root@web1 ~]# yum -y install java-1.8.0-openjdk-headless //安装JDK

[root@web1 ~]# java -version //查看JAVA版本

2)安装Tomcat(apache-tomcat-8.0.30.tar.gz软件包)

[root@web1 ~]# tar -xf apache-tomcat-8.0.30.tar.gz 

[root@web1 ~]# mv apache-tomcat-8.0.30 /usr/local/tomcat

[root@web1 ~]# ls /usr/local/tomcat 

bin/ //主程序目录

lib/ //库文件目录

logs/ //日志目录

temp/ //临时目录

work/ //自动编译目录

jsp代码转换servlet

conf/ //配置文件目录

webapps/ //页面目录

3)启动服务

[root@web1 ~]# /usr/local/tomcat/bin/startup.sh

[root@web1 ~]# firewall-cmd --set-default-zone=trusted 

[root@web1 ~]# setenforce 0

4)服务器验证端口信息

[root@web1 ~]# netstat -nutlp |grep java //查看java监听的端口 
tcp 0 0 :::8080 :::* LISTEN 2778/java tcp 0 0 ::ffff:127.0.0.1:8005 :::* LISTEN 2778/java

提示:如果检查端口时,8005端口启动非常慢,可用使用下面的命令用urandom替换random(非必须操作)。

[root@web1 ~]# mv /dev/random /dev/random.bak

[root@web1 ~]# ln -s /dev/urandom /dev/random

5)客户端浏览测试页面(proxy作为客户端)

[root@proxy ~]# firefox http://192.168.2.100:8080

步骤二:修改Tomcat配置文件

1)创建测试JSP页面

[root@web1 ~]# vim /usr/local/tomcat/webapps/ROOT/test.jsp 
<html> 
<body>
<center>Now time is: <%=new java.util.Date()%> //显示服务器当前时间
</center> 
</body>
</html>

2)重启服务

[root@web1 ~]# /usr/local/tomcat/bin/shutdown.sh

[root@web1 ~]# /usr/local/tomcat/bin/startup.sh

步骤三:验证测试

1)服务器验证端口信息

[root@web1 ~]# netstat -nutlp |grep java //查看java监听的端口 
tcp 0 0 :::8080 :::* LISTEN 2778/java tcp 0 0 ::ffff:127.0.0.1:8005 :::* LISTEN 2778/java

提示:如果检查端口时,8005端口启动非常慢,可用使用下面的命令用urandom替换random(非必须操作)。

[root@web1 ~]# mv /dev/random /dev/random.bak

[root@web1 ~]# ln -s /dev/urandom /dev/random

2)客户端浏览测试页面(proxy充当客户端角色)

[root@proxy ~]# firefox http://192.168.2.100:8080 

[root@proxy ~]# firefox http://192.168.2.100:8080/test.jsp

 

使用tomcat部署虚拟主机;

实现两个基于域名的虚拟主机,域名分别为:www.a.com和 www.b.com

使用www.a.com域名访问的页面根路径为/usr/local/tomcat/a/ROOT

使用www.b.com域名访问的页面根路径为/usr/local/tomcat/b/base

访问www.a.com/test时,页面自动跳转到/var/www/html目录下的页面

访问页面时支持SSL加密通讯

私钥、证书存储路径为/usr/local/tomcat/conf/cert

每个虚拟主机都拥有独立的访问日志文件

配置tomcat集群环境

1.创建2个域名虚拟主机,修改下面2个参数。

# cat /usr/local/tomcat/conf/server.xml
<Server>
   <Service>
     <Connector port=8080 />
     <Connector port=8009 />
     <Engine name="Catalina" defaultHost="localhost">                //默认首页
        <Host name="www.a.com" appBase="a" unpackWARS="true" autoDeploy="true">
        </Host>
        <Host name="www.b.com" appBase="b" unpackWARS="true" autoDeploy="true">
        </Host>
    … …

**语法格式 :严格区分大小写,开头结尾对应 appBase存放目录地址 unpackWARS 自动解压java压缩包 autoDeploy 自动部署. 

2.)创建虚拟主机对应的页面根路径

[root@web1 ~]# mkdir -p /usr/local/tomcat/{a,b}/ROOT 

[root@web1 ~]# echo "AAA" > /usr/local/tomcat/a/ROOT/index.html 

[root@web1 ~]# echo "BBB" > /usr/local/tomcat/b/ROOT/index.html

3)重启Tomcat服务器

[root@web1 ~]# /usr/local/tomcat/bin/shutdown.sh 

[root@web1 ~]# /usr/local/tomcat/bin/startup.sh

4)客户端设置host文件,并浏览测试页面进行测试(proxy充当客户端角色)

[root@proxy ~]# vim /etc/hosts

… … 

192.168.2.100 www.a.com www.b.com 

[root@proxy ~]# firefox http://www.a.com:8080/ //注意访问的端口为8080 

[root@proxy ~]# firefox http://www.b.com:8080/

 

步骤二:修改www.b.com网站的首页目录为base

1.使用docBase参数可以修改默认网站首页路径

[root@web1~] #vim /usr/locl/tomcat/conf/sever.xml
<Host name="www.b.com" appBase="b" unpackWARS="true" autoDeploy="true">
<Context path="" docBase="base"/>            //修改默认网站路径 
</Host>
......
[root@web1 ~]# mkdir  /usr/local/tomcat/b/base
[root@web1 ~]# echo "BASE" > /usr/local/tomcat/b/base/index.html
[root@web1 ~]# /usr/local/tomcat/bin/shutdown.sh         //先关闭服务
[root@web1 ~]# /usr/local/tomcat/bin/startup.sh             // 再重起服务

步骤三;实现跳转

1)当用户访问http://www.a.com/test打开/var/www/html目录下的页面

[

[root@web1 ~]# vim /usr/local/tomcat/conf/server.xml
… …
<Host name="www.a.com" appBase="a" unpackWARS="true" autoDeploy="true">
<Context path="/test" docBase="/var/www/html/" />       //添加实现页面跳转,同一个页面下可以写多个跳转。
</Host>
<Host name="www.b.com" appBase="b" unpackWARS="true" autoDeploy="true">
<Context path="" docBase="base" />
</Host>
… …
[root@web1 ~]# echo "Test" > /var/www/html/index.html 
[root@web1 ~]# /usr/local/tomcat/bin/shutdown.sh
[root@web1 ~]# /usr/local/tomcat/bin/startup.sh

2)测试查看页面是否正确(proxy充当客户端角色)

[root@proxy ~]# firefox http://www.a.com:8080/test  //返回/var/www/html/index.html的内容 //注意,访问的端口为8080

步骤四:配置Tomcat支持SSL加密网站 ,tomcat一个端口支持多个域名使用(通常花钱购买)

1)创建加密用的私钥和证书文件

[root@web1 ~]# keytool -genkeypair -alias tomcat -keyalg RSA -keystore /usr/local/tomcat/keystore      
                                                                                                                                  //提示输入密码为:123456
//-genkeypair     生成密钥对
//-alias tomcat     密钥别名
//-keyalg RSA     定义密钥算法为RSA算法
//-keystore         定义密钥文件存储在:/usr/local/tomcat/keystore

2)再次修改server.xml配置文件,创建支持加密连接的Connector

[root@web1 ~]# vim /usr/local/tomcat/conf/server.xml
… …
<Connector port="8443" protocol="org.apache.coyote.http11.Http11NioProtocol"
maxThreads="150" SSLEnabled="true" scheme="https" secure="true"
keystoreFile="/usr/local/tomcat/keystore" keystorePass="123456" clientAuth="false" sslProtocol="TLS" />
   //需要添加密钥目录地址 keystoreFile       密钥密码 keystorePass

//备注,默认这段Connector被注释掉了,打开注释,添加密钥信息即可

3)重启Tomcat服务器

[root@web1 ~]# /usr/local/tomcat/bin/shutdown.sh

[root@web1 ~]# /usr/local/tomcat/bin/startup.sh

4)客户端设置host文件,并浏览测试页面进行测试(proxy充当客户端角色)

[root@proxy ~]# vim /etc/hosts
… …
192.168.2.100      www.a.com  www.b.com
[root@proxy ~]# firefox https://www.a.com:8443/
[root@proxy ~]# firefox https://www.b.com:8443/
[root@proxy ~]# firefox https://192.168.2.100:8443/

步骤五:配置Tomcat日志

TOMCAT 日志文件 /usr/local/tomcat/logs/目录

catalina.out catalina.2019-06-20.log 主tomcat日志文件

[root@web1 ~]# vim /usr/local/tomcat/conf/server.xml
.. ..
<Host name="www.a.com" appBase="a" unpackWARS="true" autoDeploy="true">
<Context path="/test" docBase="/var/www/html/" />
#从默认localhost虚拟主机中把Valve这段复制过来,适当修改下即可
<Valve className="org.apache.catalina.valves.AccessLogValve" directory="logs"
               prefix=" a_access" suffix=".txt"
               pattern="%h %l %u %t &quot;%r&quot; %s %b" />
</Host>
<Host name="www.b.com" appBase="b" unpackWARS="true" autoDeploy="true">
<Context path="" docBase="base" />
<Valve className="org.apache.catalina.valves.AccessLogValve" directory="logs"       // directory 日志存位置
               prefix=" b_access" suffix=".txt"          //prefix文件名  suffix阔展名   可以修改
               pattern="%h %l %u %t &quot;%r&quot; %s %b" />
</Host>                                                                    //pattern 内值时间变量
.. ..

2)重启Tomcat服务器

[root@web1 ~]# /usr/local/tomcat/bin/shutdown.sh

[root@web1 ~]# /usr/local/tomcat/bin/startup.sh

3)查看服务器日志文件

[root@web1 ~]# ls /usr/local/tomcat/logs/

步骤六:(配置Tomcat集群)

1) 在192.168.4.5主机上配置Nginx调度器

[root@proxy ~]# vim  /usr/local/nginx/conf/nginx.conf
http{
    upstream toms {
        server 192.168.2.100:8080;
        server 192.168.2.200:8080;
    }
    server  {
        listen 80;
        server_name localhost;
        location / {
            proxy_pass  http://toms;
        }
    }
}  

2) 在192.168.2.100和192.168.2.200主机上配置Tomcat调度器

以下以Web1为例:

[root@web1 ~]# yum -y install java-1.8.0-openjdk //安装JDK 

[root@web1 ~]# yum -y install java-1.8.0-openjdk-headless //安装JDK 

[root@web1 ~]# tar -xzf apache-tomcat-8.0.30.tar.gz 

[root@web1 ~]# mv apache-tomcat-8.0.30 /usr/local/tomcat

 

3)启动服务

[root@web1 ~]# /usr/local/tomcat/bin/startup.sh

4) 客户端验证

为了防止有数据缓存,可以使用真实主机的google-chrome访问代理服务器,输入Ctrl+F5刷新页面

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值