27、Tomcat服务的安装与配置
阅读原文时间:2023年07月10日阅读:1

服务器名称

ip地址

slave-node1

172.16.1.91

27.1、 Tomcat简介:

Tomcat是Apache软件基金会(Apache Software Foundation)的Jakarta 项目中的一个核心项目,由Apache、Sun和其他一些公司及个人共同开发而成。

Tomcat服务器是一个免费的开放源代码的Web应用服务器,属于轻量级应用服务器,在中小型系统和并发访问用户不是很多的场合下被普遍使用,是开发和调试

JSP程序的首选。Tomcat和Nginx、Apache(httpd)、lighttpd等Web服务器一样,具有处理HTML页面的功能,另外它还是一个Servlet和JSP容器,独立的Servlet容器

是Tomcat的默认模式。不过,Tomcat处理静态HTML的能力不如Nginx/Apache服务器。目前Tomcat最新版本为9.0。Java容器还有resin、weblogic等。

27.2、软件准备:

JDK下载:http://www.oracle.com/technetwork/java/javase/downloads/jdk8-downloads-2133151.html

Tomcat下载:https://tomcat.apache.org/download-80.cgi

[root@slave-node1 ~]# cd tools/

[root@slave-node1 tools]# rz -y

rz waiting to receive.

Starting zmodem transfer. Press Ctrl+C to cancel.

Transferring apache-tomcat-8.5.37.tar.gz…

100% 9427 KB 9427 KB/sec 00:00:01 0 Errors

Transferring jdk-8u192-linux-x64.tar.gz…

100% 187262 KB 17023 KB/sec 00:00:11 0 Errors

27.3、准备java环境:

[root@slave-node1 tools]# tar -xzf jdk-8u192-linux-x64.tar.gz -C /application/

[root@slave-node1 tools]# mkdir /application/

[root@slave-node1 tools]# ln -s /application/jdk1.8.0_192/ /application/jdk

[root@slave-node1 tools]# sed -i.ori '$a export JAVA_HOME=/application/jdk\nexport CLASSPATH=$JAVA_HOME/lib/tools.jar:$JAVA_HOME/jre/lib/rt.jar\nexport PATH=$JAVA_HOME/bin:$PATH' /etc/profile

[root@slave-node1 tools]# source /etc/profile

[root@slave-node1 tools]# java -version

java version "1.8.0_192"

Java(TM) SE Runtime Environment (build 1.8.0_192-b12)

Java HotSpot(TM) 64-Bit Server VM (build 25.192-b12, mixed mode)

[root@slave-node1 tools]# echo $JAVA_HOME

/application/jdk

27.4、准备tomcat环境:

[root@slave-node1 tools]# tar -xzf apache-tomcat-8.5.37.tar.gz -C /application/

[root@slave-node1 tools]# ln -s /application/apache-tomcat-8.5.37/ /application/tomcat

27.5、tomcat目录介绍:

[root@slave-node1 tools]# tree /application/tomcat/ -L 1

.

├── bin #用于启动、关闭tomcat或其它功能的脚本

├── BUILDING.txt

├── conf #用于配置tomcat的xml文件

├── CONTRIBUTING.md

├── lib #存放web应用能访问的JAR包

├── LICENSE

├── logs #catalina和其它web应用程序的日志文件

├── NOTICE

├── README.md

├── RELEASE-NOTES

├── RUNNING.txt

├── temp #存放临时文件的目录

├── webapps #web应用程序根目录,即站点目录

└── work #存放产生有jsp编译出的servlet的.java和.class文件

7 directories, 7 files

[root@slave-node1 tools]# tree /application/tomcat/webapps/ -L 1

.

├── docs #tomcat帮助文档目录

├── examples #web应用实例目录

├── host-manager #管理目录

├── manager #管理目录

└── ROOT #默认网站根目录

27.5、启动tomcat:

使用普通用户'tomcat'启动tomcat服务,能够提高系统的安全性;

[root@slave-node1 tools]# useradd tomcat

[root@slave-node1 tools]# chown -R tomcat.tomcat /application/tomcat/

[root@slave-node1 tools]# su - tomcat

[root@slave-node1 ~]$ /application/tomcat/bin/startup.sh

Using CATALINA_BASE: /application/tomcat

Using CATALINA_HOME: /application/tomcat

Using CATALINA_TMPDIR: /application/tomcat/temp

Using JRE_HOME: /application/jdk

Using CLASSPATH: /application/tomcat/bin/bootstrap.jar:/application/tomcat/bin/tomcat-juli.jar

Tomcat started.

[root@slave-node1 ~]$ su - root

[root@slave-node1 ~]# netstat -tunlp | grep java

tcp 0 0 ::ffff:127.0.0.1:8005 :::* LISTEN 14770/java

tcp 0 0 :::8009 :::* LISTEN 14770/java

tcp 0 0 :::8080 :::* LISTEN 14770/java

[root@slave-node1 ~]# ps -ef | grep "tomcat" | grep -v "grep"

root 12081 11488 0 23:50 pts/1 00:00:00 su - tomcat

tomcat 12082 12081 0 23:50 pts/1 00:00:00 -bash

tomcat 12138 1 4 23:51 pts/1 00:00:20 //bin/java -Djava.util.logging.config.file=/application/tomcat/conf/logging.properties -Djava.util.logging.manag

er=org.apache.juli.ClassLoaderLogManager -Djdk.tls.ephemeralDHKeySize=2048 -Djava.protocol.handler.pkgs=org.apache.catalina.webresources -Dorg.apache.catalina.security.SecurityListener.UMASK=0027 -Dcom.sun.management.jmxremote -Dcom.sun.management.jmxremote.port=12345 -Dcom.sun.management.jmxremote.authenticate=false -Dcom.sun.management.jmxremote.ssl=false -Djava.rmi.server.hostname=172.16.1.91 -Dignore.endorsed.dirs= -classpath /application/tomcat/bin/bootstrap.jar:/application/tomcat/bin/tomcat-juli.jar -Dcatalina.base=/application/tomcat -Dcatalina.home=/application/tomcat -Djava.io.tmpdir=/application/tomcat/temp org.apache.catalina.startup.Bootstrap start

27.6、访问网站:

27.7、tomcat日志:

[root@slave-node1 ~]# tree /application/tomcat/logs/ -L 1

.

├── catalina.2018-12-26.log

├── catalina.out #tomcat的实时日志

├── host-manager.2018-12-26.log

├── localhost.2018-12-26.log

├── localhost_access_log.2018-12-26.txt #访问日志

└── manager.2018-12-26.log

0 directories, 6 files

27.8、tomcat配置文件:

[root@slave-node1 ~]# tree /application/tomcat/conf/ -L 1

.

├── Catalina

├── catalina.policy

├── catalina.properties

├── context.xml

├── jaspic-providers.xml

├── jaspic-providers.xsd

├── logging.properties

├── server.xml #tomcat主配置文件

├── tomcat-users.xml #tomcat管理用户配置文件

├── tomcat-users.xsd

└── web.xml

1 directory, 10 files

27.9、tomcat管理:

测试功能,用于测试环境,生产环境不要用;

Tomcat管理功能用于对Tomcat自身以及部署在Tomcat上的应用进行管理的web应用。在默认情况下是处于禁用状态的。

如果需要开启这个功能,就需要配置管理用户,即配置前面说过的tomcat-users.xml。

[root@slave-node1 ~]# vim /application/tomcat/conf/tomcat-users.xml

#在此行前加入上面三行

[root@slave-node1 ~]# vim /application/tomcat/webapps/manager/META-INF/context.xml

<Valve className="org.apache.catalina.valves.RemoteAddrValve"

allow="127\.\d+\.\d+\.\d+|::1|0:0:0:0:0:0:0:1" />

#需要将该段代码注释掉,不然会报403错误;

<Manager sessionAttributeValueClassNameFilter="java\.lang\.(?:Boolean|Integer|Long|Number|String)|org\.apache\.catalina\.filters\.CsrfPreventionFilter\$LruCache

(?:\$1)?|java\.util\.(?:Linked)?HashMap"/>

#重启tomcat:

[root@slave-node1 ~]# su - tomcat /application/tomcat/bin/shutdown.sh

[root@slave-node1 ~]# su - tomcat /application/tomcat/bin/startup.sh

#访问:

27.10、tomcat主配置文件server.xml详解:

1、server.xml组件类别:

(1)顶级组件:位于整个配置的顶层,如server;

(2)容器类组件:可以包含其它的组件,如service、engine、host、context

(3)连接类组件:连接用户请求至tomcat,如connector

(4)被嵌套类组件:位于一个容器当中,不能包含其他组件,如value、logger

2、组件:

3、组件详解:

(1)engine:核心容器组件,catalina引擎,负责通过connector接收用户请求,并处理请求,将请求转至对应的虚拟主机host。

(2)host:类似于httpd中的虚拟主机,一般而言支持基于FQDN的虚拟主机。

(3)context:定义一个应用程序,是一个最内层的容器类组件(不能再嵌套)。配置context的主要目的指定对应对的webapp的

根目录,类似于httpd的alias,其还能为webapp指定额外的属性,如部署方式等。

(4)connector:接收用户请求,类似于httpd的listen配置监听端口的。

(5)service:将connector关联至engine,因此一个service内部可以有多个connector,但只能有一个引擎engine。service内部

有两个connector,一个engine。因此,一般情况下一个server内部只有一个service,一个service内部只有一个engine,但一个service

内部可以有多个connector。

(6)server:表示一个运行于JVM中的tomcat实例。

(7)Valve:阀门,拦截请求并在将其转至对应的webapp前进行某种处理操作,可以用于任何容器中,比如记录日志(access log valve)、

基于IP做访问控制(remote address filter valve)。

(8)logger:日志记录器,用于记录组件内部的状态信息,可以用于除context外的任何容器中。

(9)realm:可以用于任意容器类的组件中,关联一个用户认证库,实现认证和授权。可以关联的认证库有两种:UserDatabaseRealm、

MemoryRealm和JDBCRealm。

(10)UserDatabaseRealm:使用JNDI自定义的用户认证库。

(11)MemoryRealm:认证信息定义在tomcat-users.xml中。

(12)JDBCRealm:认证信息定义在数据库中,并通过JDBC连接至数据库中查找认证用户。

4、 配置文件内容详解:

<Resource name="UserDatabase" auth="Container"

type="org.apache.catalina.UserDatabase"

description="User database that can be updated and saved"

factory="org.apache.catalina.users.MemoryUserDatabaseFactory"

pathname="conf/tomcat-users.xml" />

<Connector port="8080" protocol="HTTP/1.1"

connectionTimeout="20000"

redirectPort="8443" />

<Realm className="org.apache.catalina.realm.UserDatabaseRealm"

resourceName="UserDatabase"/>

<Host name="localhost" appBase="webapps"

unpackWARs="true" autoDeploy="true">

<Valve className="org.apache.catalina.valves.AccessLogValve" directory="logs"

prefix="localhost_access_log" suffix=".txt"

pattern="%h %l %u %t "%r" %s %b" />

27.11、web站点部署:

1、上线的代码有两种方式,第一种方式是直接将程序目录放在webapps目录下面然后输入http://172.16.1.91:8080/web_name进行访问;第二种方式是使用开发工具将程序打包成war包,然后上传到webapps目录下面,默认情况下回自动解压;

2、打war包的方法:

(1)jar -cf webapp.war webapp\" #表示将指定的文件夹进行打包;

(2)jar -cf webapp.war . #表示将当前目录下的所有文件进行打包;

3、解压war包的方法:

jar -xf webapp.war

27.12、tomcat多实例配置:

1、环境准备:

(1)复制出多个tomcat应用:

[root@slave-node1 ~]# cp -a /application/apache-tomcat-8.5.37/ /application/apache-tomcat-8.5.37-8080/

[root@slave-node1 ~]# cp -a /application/apache-tomcat-8.5.37/ /application/apache-tomcat-8.5.37-8081/

[root@slave-node1 ~]# rm -rf /application/apache-tomcat-8.5.37/

[root@slave-node1 ~]# rm -f /application/tomcat

[root@slave-node1 ~]# ln -s /application/apache-tomcat-8.5.37-8080/ /application/tomcat-8080

[root@slave-node1 ~]# ln -s /application/apache-tomcat-8.5.37-8081/ /application/tomcat-8081

(2)为tomcat应用包赋予普通用户的权限:

[root@slave-node1 ~]# chown -R tomcat.tomcat /application/tomcat-8080/

[root@slave-node1 ~]# chown -R tomcat.tomcat /application/tomcat-8081/

(3)创建站点目录:

[root@slave-node1 ~]# mkdir -p /data/www/tomcat/ROOT/

[root@slave-node1 ~]# cd /data/www/tomcat/ROOT/

[root@slave-node1 ROOT]# rz -y

[root@slave-node1 ROOT]# ls

memtest.war

[root@slave-node1 ROOT]# jar -xf memtest.war && rm -f memtest.war && mv meminfo.jsp index.jsp

[root@slave-node1 ROOT]# ls

index.jsp META-INF

[root@slave-node1 ROOT]# cd ~

[root@slave-node1 ~]# chown -R tomcat.tomcat /data/www/tomcat/

2、修改server.xml文件:

(1)修改端口号:

[root@slave-node1 ~]# sed -i.ori '22s#8005#8010#;69s#8080#8080#' /application/tomcat-8080/conf/server.xml

[root@slave-node1 ~]# sed -i.ori '22s#8005#8011#;69s#8080#8081#' /application/tomcat-8081/conf/server.xml

(2)配置tomcat多实例使用同一个站点目录下的应用:

[root@slave-node1 ~]# sed -i '148s#webapps#/data/www/tomcat#' /application/tomcat-8080/conf/server.xml

[root@slave-node1 ~]# sed -i '148s#webapps#/data/www/tomcat#' /application/tomcat-8081/conf/server.xml

3、tomcat优化配置:

(1)屏蔽dns查询、增大服务器超时时间、限制最大并发量(性能优化):

[root@slave-node1 ~]# sed -i '70s#connectionTimeout="20000"#connectionTimeout="6000" enableLookups="false" acceptCount="800"#' /application/tomcat-8080/conf/server.xml

[root@slave-node1 ~]# sed -i '70s#connectionTimeout="20000"#connectionTimeout="6000" enableLookups="false" acceptCount="800"#' /application/tomcat-8081/conf/server.xml

(2)关闭ajp连接(安全优化):

[root@slave-node1 ~]# sed -i '116s##2024 .

浙ICP备15029886号