tomcat多实例部署

Posted liliyang

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了 tomcat多实例部署相关的知识,希望对你有一定的参考价值。

Tomcat 的基本组成

tomcat的单实例部署见https://www.cnblogs.com/liliyang/p/9742284.html

安装好之后,看下目录结构:

[[email protected] tomcat]# ll
total 96
drwxr-xr-x  2 root root  4096 Aug 28 00:08 bin
drwxr-xr-x  3 root root   198 Oct  5 12:30 conf
drwxr-xr-x  2 root root  4096 Aug 27 22:32 lib
-rw-r--r--  1 root root 57011 Dec  1  2017 LICENSE
drwxr-xr-x  2 root root  4096 Oct  5 00:11 logs
-rw-r--r--  1 root root  1444 Dec  1  2017 NOTICE
-rw-r--r--  1 root root  6792 Dec  1  2017 RELEASE-NOTES
-rw-r--r--  1 root root 16242 Dec  1  2017 RUNNING.txt
drwxr-xr-x  3 root root    49 Oct  5 00:19 temp
drwxr-xr-x 10 root root   162 Oct  4 22:11 webapps
drwxr-xr-x  3 root root    22 Aug 27 22:35 work

再介绍一下各个目录及文件:

  • bin                 :主要存放脚本文件,例如比较常用的windows和linux系统中启动和关闭脚本
  • conf               :主要存放配置文件,其中最重要的两个配置文件是server.xml和web.xml
  • lib                  :主要存放tomcat运行所依赖的包
  • LICENSE       :版权许可证,软件版权信息及使用范围等信息
  • logs               :主要存放运行时产生的日志文件,例如catalina.out(曾经掉过一个大坑)、catalina.{date}.log等
  • NOTICE    :通知信息,一些软件的所属信息和地址什么的
  • RELEASE-NOTES:发布说明,包含一些版本升级功能点
  • RUNNING.txt  :运行说明,必需的运行环境等信息
  • temp               :存放tomcat运行时产生的临时文件,例如开启了hibernate缓存的应用程序,会在该目录下生成一些文件
  • webapps        :部署web应用程序的默认目录,也就是 war 包所在默认目录
  • work               :主要存放由JSP文件生成的servlet(java文件以及最终编译生成的class文件)

 

上面是Tomcat安装后的组成部分,进入bin目录执行startup.sh或catalina.sh  start 就可以了,接着就可以在浏览器输入http://localhost:8080/访问了。

那么问题来了:当你有了三个、五个以及十个应用服务需要同时部署到同一台服务器上时,你的 Tomcat 服务正确启动方式是什么?是把上面文件全部复制出 N 多个目录么?还是有其他处理方式呢?

Tomcat 常见的几种部署场景

通常,我们在同一台服务器上对Tomcat部署需求可以分为以下几种:单实例单应用,单实例多应用,多实例单应用,多实例多应用

实例的概念可以理解为上面说的一个Tomcat目录。

  • 单实例单应用:比较常用的一种方式,只需要把你打好的war包丢在webapps目录下,执行启动 Tomcat 的脚本就行了。
  • 单实例多应用:有两个不同的 Web 项目 war 包,还是只需要丢在webapps目录下,执行启动 Tomcat 的脚本,访问不同项目加上不同的虚拟目录。这种方式要慎用在生产环境,因为重启或挂掉 Tomcat 后会影响另外一个应用的访问。
  • 多实例单应用:多个 Tomcat 部署同一个项目,端口号不同,可以利用 nginx 这么做负载均衡,当然意义不大。
  • 多实例多应用:多个 Tomcat 部署多个不同的项目。这种模式在服务器资源有限,或者对服务器要求并不是很高的情况下,可以实现多个不同项目部署在同一台服务器上的需求,来实现资源使用的最大化

本文要说的就是这种多实例多应用方式,但多个 Tomcat 就是简单的复制出一个新的 Tomcat 目录后改一下端口么?当然不是,其实真这么做也可以,当当同一台服务器部署了多个不同基于 Tomcat 的 Web 服务时,会遇到下面几个极其现实的问题。

  • 当你需要对数十台 Tomcat 版本进行升级的时候,你需要怎么做?
  • 当你需要针对每一个不同的 Web 服务分配不用的内存时,你需要怎么做?
  • 当你需要启动多台服务器时,你需要怎么做?

当然,好像上面的都不是很重要,注意,划重点,多实例部署最大作用就是最大化利用服务器资源

官方文档:

不建议复制一个又一份的全部 Tomcat 目录进行多实例的部署,说安照下图可以实现更优雅的 Tomcat 单机多实例部署:

技术分享图片

CATALINA_HOME指Tomcat安装路径,CATALINA_BASE指实例所在位置。

CATALINA_HOME路径下只需要包含bin和lib目录,
CATALINA_BASE只存放conf、webapps、logs等这些文件

这样部署的好处在于升级方便,配置及安装文件间互不影响,在不影响Tomcat实例的前提下,替换掉CATALINA_HOME中的安装文件

主机地址:10.0.0.125

环境:CentOS 7.x

1、安装JDK,见https://www.cnblogs.com/liliyang/p/9742284.html

 2、部署tomcat,按照单实例部署

mkdir -p /application/tomcat-8.5.31

cd /application/

下载或上传tomcat源码包

 tar xvf apache-tomcat-8.5.31.tar.gz 

mv apache-tomcat-8.5.31/*  /application/tomcat-8.5.31/

ln -s tomcat-8.5.31/  tomcat

echo  ‘export CATALINA_HOME="/application/tomcat"‘  >> /etc/profile
echo  ‘export PATH="${CATALINA_HOME}/bin:${PATH}"‘ >> /etc/profile

source /etc/profile

cd tomcat

mkdir tomcat-01

mv   conf/  LICENSE  logs/  NOTICE  RELEASE-NOTES  RUNNING.txt   temp/  webapps/  work/  tomcat-01

cp -a tomcat-01/  tomcat-02

[[email protected] tomcat]# ll
total 8
drwxr-x--- 2 root root 4096 Oct  5 03:55 bin
drwxr-x--- 2 root root 4096 Oct  5 03:55 lib
drwxr-xr-x 7 root root  138 Oct  5 03:59 tomcat-01
drwxr-xr-x 7 root root  138 Oct  5 03:59 tomcat-02
[[email protected] tomcat]# ll tomcat-01
total 84
drwx------ 2 root root   238 Apr 27 16:26 conf
-rw-r----- 1 root root 57092 Apr 27 16:26 LICENSE
drwxr-x--- 2 root root     6 Apr 27 16:24 logs
-rw-r----- 1 root root  1723 Apr 27 16:26 NOTICE
-rw-r----- 1 root root  7138 Apr 27 16:26 RELEASE-NOTES
-rw-r----- 1 root root 16246 Apr 27 16:26 RUNNING.txt
drwxr-x--- 2 root root    30 Oct  5 03:55 temp
drwxr-x--- 7 root root    81 Apr 27 16:24 webapps
drwxr-x--- 2 root root     6 Apr 27 16:24 work
[[email protected] tomcat]# ll tomcat-02
total 84
drwx------ 2 root root   238 Apr 27 16:26 conf
-rw-r----- 1 root root 57092 Apr 27 16:26 LICENSE
drwxr-x--- 2 root root     6 Apr 27 16:24 logs
-rw-r----- 1 root root  1723 Apr 27 16:26 NOTICE
-rw-r----- 1 root root  7138 Apr 27 16:26 RELEASE-NOTES
-rw-r----- 1 root root 16246 Apr 27 16:26 RUNNING.txt
drwxr-x--- 2 root root    30 Oct  5 03:55 temp
drwxr-x--- 7 root root    81 Apr 27 16:24 webapps
drwxr-x--- 2 root root     6 Apr 27 16:24 work

3、新建 Tomcat 启动、停止脚本

注意:多实例启停脚本中必须设定CATALINA_BASE变量

mkdir  -p  /application/tomcat/tomcat-shell/

cd    /application/tomcat/tomcat-shell/

 

cat  >>  start-tomcat01.sh <<end

#!/bin/bash
export  CATALINA_BASE="/application/tomcat/tomcat-01"
export  CATALINA_HOME="/application/tomcat"
/application/tomcat/bin/catalina.sh start

 end

 

 cat  >>  stop-tomcat01.sh <<end

#!/bin/bash
export  CATALINA_BASE="/application/tomcat/tomcat-01"
export  CATALINA_HOME="/application/tomcat"
/application/tomcat/bin/catalina.sh stop

 end

  

 cat  >>  start-tomcat02.sh <<end

#!/bin/bash
export  CATALINA_BASE="/application/tomcat/tomcat-02"
export  CATALINA_HOME="/application/tomcat"
/application/tomcat/bin/catalina.sh start

 end

  

 cat  >>  stop-tomcat02.sh <<end

#!/bin/bash
export  CATALINA_BASE="/application/tomcat/tomcat-02"
export  CATALINA_HOME="/application/tomcat"
/application/tomcat/bin/catalina.sh stop

 end 

[[email protected] tomcat-shell]# ll
total 16
-rw-r--r-- 1 root root 128 Oct  5 04:15 start-tomcat01.sh
-rw-r--r-- 1 root root 128 Oct  5 04:15 start-tomcat02.sh
-rw-r--r-- 1 root root 127 Oct  5 04:17 stop-tomcat01.sh
-rw-r--r-- 1 root root 127 Oct  5 04:17 stop-tomcat02.sh

 

修改实例2服务的启动端口

cd ../tomcat-02/conf/

 修改server.xml文件,将其中的服务端口(默认8005)、2个连接器端口(默认8080和8009)及转发端口(默认8443)全部修改,避免和tomcat01实例冲突

 

 cd ../webapps/ROOT/

cat >>index.html<<end

<html>
<title>Tomcat-02</title>
<body>
This is from tomcat-02.
</body>
</html>

end

 

cat >>/application/tomcat/tomcat-01/webapps/ROOT/index.html<<end

<html>
<title>Tomcat-01</title>
<body>
This is from tomcat-01.
</body>
</html>

end

 

chmod +x /application/tomcat/tomcat-shell/*

启动测试:

[[email protected] tomcat-shell]# /application/tomcat/tomcat-shell/start-tomcat01.sh 
Using CATALINA_BASE:   /application/tomcat/tomcat-01
Using CATALINA_HOME:   /application/tomcat
Using CATALINA_TMPDIR: /application/tomcat/tomcat-01/temp
Using JRE_HOME:        /application/jdk/jre
Using CLASSPATH:       /application/tomcat/bin/bootstrap.jar:/application/tomcat/bin/tomcat-juli.jar
Tomcat started.
[[email protected] tomcat-shell]# /application/tomcat/tomcat-shell/start-tomcat02.sh  
Using CATALINA_BASE:   /application/tomcat/tomcat-02
Using CATALINA_HOME:   /application/tomcat
Using CATALINA_TMPDIR: /application/tomcat/tomcat-02/temp
Using JRE_HOME:        /application/jdk/jre
Using CLASSPATH:       /application/tomcat/bin/bootstrap.jar:/application/tomcat/bin/tomcat-juli.jar
Tomcat started.
[[email protected] tomcat-shell]# netstat -tunlp
Active Internet connections (only servers)
Proto Recv-Q Send-Q Local Address           Foreign Address         State       PID/Program name    
tcp        0      0 0.0.0.0:2222            0.0.0.0:*               LISTEN      24892/python3       
tcp        0      0 0.0.0.0:22              0.0.0.0:*               LISTEN      19441/sshd          
tcp        0      0 0.0.0.0:5000            0.0.0.0:*               LISTEN      24892/python3       
tcp6       0      0 :::8080                 :::*                    LISTEN      96531/java          
tcp6       0      0 :::8081                 :::*                    LISTEN      96583/java          
tcp6       0      0 :::22                   :::*                    LISTEN      19441/sshd          
tcp6       0      0 127.0.0.1:8005          :::*                    LISTEN      96531/java          
tcp6       0      0 127.0.0.1:8006          :::*                    LISTEN      96583/java          
tcp6       0      0 :::8009                 :::*                    LISTEN      96531/java          
tcp6       0      0 :::8010                 :::*                    LISTEN      96583/java       

技术分享图片技术分享图片

 

停止:

[[email protected] tomcat-shell]# /application/tomcat/tomcat-shell/stop-tomcat01.sh 
Using CATALINA_BASE:   /application/tomcat/tomcat-01
Using CATALINA_HOME:   /application/tomcat
Using CATALINA_TMPDIR: /application/tomcat/tomcat-01/temp
Using JRE_HOME:        /application/jdk/jre
Using CLASSPATH:       /application/tomcat/bin/bootstrap.jar:/application/tomcat/bin/tomcat-juli.jar
[[email protected] tomcat-shell]# /application/tomcat/tomcat-shell/stop-tomcat02.sh  
Using CATALINA_BASE:   /application/tomcat/tomcat-02
Using CATALINA_HOME:   /application/tomcat
Using CATALINA_TMPDIR: /application/tomcat/tomcat-02/temp
Using JRE_HOME:        /application/jdk/jre
Using CLASSPATH:       /application/tomcat/bin/bootstrap.jar:/application/tomcat/bin/tomcat-juli.jar
[[email protected] tomcat-shell]# netstat -tunlp
Active Internet connections (only servers)
Proto Recv-Q Send-Q Local Address           Foreign Address         State       PID/Program name    
tcp        0      0 0.0.0.0:2222            0.0.0.0:*               LISTEN      24892/python3       
tcp        0      0 0.0.0.0:22              0.0.0.0:*               LISTEN      19441/sshd          
tcp        0      0 0.0.0.0:5000            0.0.0.0:*               LISTEN      24892/python3       
tcp6       0      0 :::22                   :::*                    LISTEN      19441/sshd   

 

























以上是关于 tomcat多实例部署的主要内容,如果未能解决你的问题,请参考以下文章

tomcat 多实例部署以及负载均衡配置

Tomcat 多实例部署

Tomcat多实例单应用部署方案 (转)

tomcat 多实例部署

附:Tomcat简介&JPress部署&多实例&优化

tomcat多实例的部署