服务器名称
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" />
#需要将
<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#