Loading

27、Tomcat服务的安装与配置



服务器名称

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

<role rolename="manager-gui"/>

<role rolename="admin-gui"/>

<user username="tomcat" password="tomcat" roles="manager-gui,admin-gui"/>

</tomcat-users> #在此行前加入上面三行

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

<Context antiResourceLocking="false" privileged="true" >

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

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

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

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

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

</Context>

#重启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、组件:

<server>

<service>

<connector />

<engine>

<host>

<context></context>

</host>

<host>

<context></context>

</host>

</engine>

</service>

</server>

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、 配置文件内容详解:

<?xml version="1.0" encoding="UTF-8"?>

<Server port="8005" shutdown="SHUTDOWN">

<!-- "port"表示Tomcat监听shutdown命令的端口,默认是8005,"shutdown"表示

指定终止Tomcat服务器运行时发给Tomcat服务器的shutdown监听端口的字符串;

-->

<Listener className="org.apache.catalina.startup.VersionLoggerListener" />

<Listener className="org.apache.catalina.core.AprLifecycleListener" SSLEngine="on" />

<Listener className="org.apache.catalina.core.JreMemoryLeakPreventionListener" />

<Listener className="org.apache.catalina.mbeans.GlobalResourcesLifecycleListener" />

<Listener className="org.apache.catalina.core.ThreadLocalLeakPreventionListener" />


<GlobalNamingResources>

<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" />

</GlobalNamingResources>


<Service name="Catalina">

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

connectionTimeout="20000"

redirectPort="8443" />

<!--

Connector:接收用户请求,类似于httpd的listen配置监听端口

port:指定服务器端要创建的端口号,并在这个端口监听来自客户端的请求

address:指定连接器监听的地址,默认为所有地址(即0.0.0.0)

protocol:连接器使用的协议,支持HTTP(tomcat与nginx建立通信)和AJP(tomcat与apache建立通信)

minProcessors:服务器最小创建的处理请求的线程数(最小并发数)

maxProcessors:服务器最大创建的处理请求的线程数(最大并发数)

enableLookups:为true(默认)时调用"request.getRemoteHost()"方法进行DNS查询获得远程客户端的实际主机

名,为false则不进行DNS查询,返回的是远程客户端的ip地址;

redirectPort:指定服务器正在处理http请求时收到了一个SSL传输请求后重定向的端口号

acceptCount:指定当所有可以使用的处理请求的线程数都被使用时,可以放到处理队列中的请求数,超过

这个数的请求将不予处理

connectionTimeout:指定连接超时的时间数(以毫秒为单位)

-->

<Connector port="8009" protocol="AJP/1.3" redirectPort="8443" />

<!-- 连接apache时使用,端口号默认为8009,如果在多实例的情况下,不注释只会起一个端口,不会影响到多实例的启动,

在生产环境中使用的是nginx做负载均衡,该段配置会被注释掉;

-->

<Engine name="Catalina" defaultHost="localhost">

<!-- 配置tomcat接收用户请求的默认主机,一般不做修改,默认是本地主机 -->


<Realm className="org.apache.catalina.realm.LockOutRealm">

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

resourceName="UserDatabase"/>

</Realm>


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

unpackWARs="true" autoDeploy="true">

<!--

Host:表示一个虚拟主机

name:虚拟主机的域名,一般不做修改,因为一般一个tomcat服务只放一个站点,类似于nginx中的域名配置;

appBase:应用程序基本目录(站点目录),即存放应用程序的目录,默认appBase="webapps",相对于

"CATALINA_HOME"而言的,也可以写绝对路径,默认站点应用程序在该目录的ROOT目录下;

unpackWARs:为true(默认)表示tomcat会自动将WAR文件解压,false表示不解压

autoDeploy:在tomcat启动时,是否自动部署(默认自动部署)

xmlValidation:是否启动xml的校验功能,默认xmlValidation="false"

xmlNamespaceAware:检测名称空间,默认xmlNamespaceAware="false"

-->

<!-- <Context path="" docBase="web_name" debug="0" reloadable="true"/> -->

<!--

Context:表示一个web应用程序,通常为WAR文件

path:表示此web应用程序的url的前缀,这样请求的url为http://localhost:8080/path/<应用程序名>

docBase:应用程序的存放的路径,起始路径为此Context所属Host中appBase定义的路径,可以使用相对路径也可以使用绝对路径

reloadable:为true时tomcat会自动检测应用程序的/WEB-INF/lib和/WEB-INF/classes目录的变化,在不重启tomcat的情况下自动装载新

的应用程序(默认下是没有开启该功能的)

说明:该配置是设置默认站点应用程序的一种方法,优先级最高;

-->

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

prefix="localhost_access_log" suffix=".txt"

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

</Host>

</Engine>

</Service>

</Server>

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#<Connector port="8009" protocol="AJP/1.3" redirectPort="8443" />#<!-- <Connector port="8009" protocol="AJP/1.3" redirectPort="8443" /> -->#' /application/tomcat-8080/conf/server.xml

[root@slave-node1 ~]# sed -i '116s#<Connector port="8009" protocol="AJP/1.3" redirectPort="8443" />#<!-- <Connector port="8009" protocol="AJP/1.3" redirectPort="8443" /> -->#' /application/tomcat-8081/conf/server.xml

(3)jvm优化(性能优化):

[root@slave-node1 ~]# sed -i.ori '117a JAVA_OPTS="-Djava.awt.headless=true -Dfile.encoding=UTF-8 -server -Xms1024m -Xmx1024m \\\

-XX:NewSize=512m -XX:MaxNewSize=512m \\\

-XX:PermSize=512m -XX:MaxPermSize=512m"' \

/application/tomcat-8080/bin/catalina.sh

[root@slave-node1 ~]# sed -i.ori '117a JAVA_OPTS="-Djava.awt.headless=true -Dfile.encoding=UTF-8 -server -Xms1024m -Xmx1024m \\\

-XX:NewSize=512m -XX:MaxNewSize=512m \\\

-XX:PermSize=512m -XX:MaxPermSize=512m"' \

/application/tomcat-8081/bin/catalina.sh

(4)删除tomcat管理配置(安全优化):

[root@slave-node1 ~]#

dir_array=(docs examples host-manager html manager)

for n in {0..1}; do

for ((i=0;i<${#dir_array[*]};i++)); do

rm -rf /application/tomcat-808$n/webapps/${dir_array[$i]}

done

done

[root@slave-node1 ~]# for n in {0..1};do rm -rf /application/tomcat-808$n/webapps/ROOT/*;done

4、启动多实例:

[root@slave-node1 ~]# for n in {0..1};do su - tomcat /application/tomcat-808$n/bin/startup.sh;sleep 20s;done

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

tcp 0 0 ::ffff:127.0.0.1:8010 :::* LISTEN 3547/java

tcp 0 0 ::ffff:127.0.0.1:8011 :::* LISTEN 3567/java

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

tcp 0 0 :::8081 :::* LISTEN 3567/java

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

tomcat 27195 1 1 18:27 pts/0 00:00:09 //bin/java -Djava.util.logging.config.file=/application/tomcat-8080/conf/logging.properties -Djava.util.logging.

manager=org.apache.juli.ClassLoaderLogManager -Djava.awt.headless=true -Dfile.encoding=UTF-8 -server -Xms1024m -Xmx1024m -XX:NewSize=512m -XX:MaxNewSize=512m -XX:PermSize=512m -XX:MaxPermSize=512m -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-8080/bin/bootstrap.jar:/application/tomcat-8080/bin/tomcat-juli.jar -Dcatalina.base=/application/tomcat-8080 -Dcatalina.home=/application/tomcat-8080 -Djava.io.tmpdir=/application/tomcat-8080/temp org.apache.catalina.startup.Bootstrap start

tomcat 27239 1 1 18:27 pts/0 00:00:08 //bin/java -Djava.util.logging.config.file=/application/tomcat-8081/conf/logging.properties -Djava.util.logging.

manager=org.apache.juli.ClassLoaderLogManager -Djava.awt.headless=true -Dfile.encoding=UTF-8 -server -Xms1024m -Xmx1024m -XX:NewSize=512m -XX:MaxNewSize=512m -XX:PermSize=512m -XX:MaxPermSize=512m -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=12346 -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-8081/bin/bootstrap.jar:/application/tomcat-8081/bin/tomcat-juli.jar -Dcatalina.base=/application/tomcat-8081 -Dcatalina.home=/application/tomcat-8081 -Djava.io.tmpdir=/application/tomcat-8081/temp org.apache.catalina.startup.Bootstrap start

5、测试:

(1)在浏览器中输入http://172.16.1.91:8080:

(2)在浏览器中输入http://172.16.1.91:8081:

27.13、tomcat的nginx负载均衡:

1、安装nginx:

(1)下载nginx:

cd /tools/

wget http://nginx.org/download/nginx-1.16.0.tar.gz

(2)安装:

yum install openssl openssl-devel gcc pcre pcre-devel -y

useradd -M -s /sbin/nologin www

tar -xzf nginx-1.16.0.tar.gz

cd /tools/nginx-1.16.0/

./configure --user=www --group=www --with-http_ssl_module --with-http_stub_status_module --prefix=/application/nginx-1.16.0/

echo $?

0

make install

echo $?

0

ln -s /application/nginx-1.16.0/ /application/nginx

(3)启动nginx:

/application/nginx/sbin/nginx

ps -ef | grep nginx | grep -v "grep"

root 5230 1 0 23:56 ? 00:00:00 nginx: master process /application/nginx/sbin/nginx

www 5231 5230 0 23:56 ? 00:00:00 nginx: worker process

2、配置nginx负载均衡:

(1)清理注释的配置:

sed -ri.ori "/#|^$/d" /application/nginx/conf/nginx.conf

(2)创建nginx的配置文件目录:

mkdir /application/nginx/conf/conf.d/ -p

(3)修改配置文件:

1)主配置文件:

vim /application/nginx/conf/nginx.conf

worker_processes 1;

events {

worker_connections 1024;

}

http {

include mime.types;

default_type application/octet-stream;

sendfile on;

keepalive_timeout 65;

include conf.d/*.conf;

}

2)包含配置文件:

vim /application/nginx/conf/conf.d/tomcat.conf

upstream tomcat_pools {

server 127.0.0.1:8080 weight=1 max_fails=3 fail_timeout=60;

server 127.0.0.1:8081 weight=1 max_fails=3 fail_timeout=60;

}


server {

listen 80;

server_name localhost;

location / {

proxy_pass http://tomcat_pools;

proxy_set_header Host $host;

proxy_set_header X-Real-IP $remote_addr;

}

}

3)验证配置文件:

/application/nginx/sbin/nginx -t

nginx: the configuration file /application/nginx-1.16.0//conf/nginx.conf syntax is ok

nginx: configuration file /application/nginx-1.16.0//conf/nginx.conf test is successful

3、重启nginx:

/application/nginx/sbin/nginx -s reload

ps -ef | grep nginx | grep -v "grep"

root 5230 1 0 7月17 ? 00:00:00 nginx: master process /application/nginx/sbin/nginx

www 7612 5230 0 00:42 ? 00:00:00 nginx: worker process

netstat -tunlp | grep nginx

tcp 0 0 0.0.0.0:80 0.0.0.0:* LISTEN 5230/nginx: master

4、测试:

多次刷新页面时,页面上监控tomcat容器内存情况的数据会依次轮询;

1)http://172.16.1.91

2)http://172.16.1.91

27.14、小结:

1、tomcat安全优化:

(1)降权启动:

创建tomcat用户,并使用该用户启动tomcat;

(2)telnet管理端口保护:

更改8005 shutdown端口,监听的是127.0.0.1;

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

tcp6 0 0 127.0.0.1:8010 :::* LISTEN 2414/java

[root@slave-node1 ~]# telnet 127.0.0.1 8010

Trying 127.0.0.1...

Connected to 127.0.0.1.

Escape character is '^]'.

SHUTDOWN

Connection closed by foreign host.

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

(3)ajp连接端口保护:

关闭server.xml配置文件中ajp连接配置项;

(4)禁用管理端:

删除webapps应用程序下的"docs examples host-manager html manager"目录,并清空

ROOT目录下的所有内容;

2、tomcat性能优化:

(1)屏蔽dns查询:

在server.xml配置文件配置tomcat访问端口号处添加'enableLookups="false"'

(2)jvm优化:

1)说明:

Tomcat最吃内存,只要内存足够,这只猫就跑的很快;

如果系统资源有限,那就需要进行调优,提高资源使用率;

2)优化配置:

优化catalina.sh配置文件,在catalina.sh配置文件中117行的下面添加以下代码:

JAVA_OPTS="-Djava.awt.headless=true -Dfile.encoding=UTF-8 -server -Xms1024m -Xmx1024m -XX:NewSize=512m -XX:MaxNewSize=512m -XX:PermSize=512m -XX:MaxPermSize=512m"

3)jvm优化参数说明:

server:一定要作为第一个参数,在多个CPU时性能佳;

-Xms:初始堆内存Heap大小,使用的最小内存,cpu性能高时此值应设的大一些;

-Xmx:初始堆内存heap最大值,使用的最大内存;

#上面两个值是分配JVM的最小和最大内存,取决于硬件物理内存的大小,建议均设为物理内存的一半;

-XX:PermSize:设定永久保存区域内存的初始空间;

-XX:MaxPermSize:设定永久保存区域内存的最大空间;

-XX:NewSize:表示新生代码初始内存的大小;

-XX:MaxNewSize:表示新生代码可被分配内存的最大上限;

#上面4个参数均设置为分配给jvm内存的一半;

-Xss 15120:这使得JBoss每增加一个线程(thread)就会立即消耗15M内存,而最佳值应该是128K,默认值好像是512KB;

+XX:AggressiveHeap:会使得 Xms没有意义。这个参数让jvm忽略Xmx参数,疯狂地吃完一个G物理内存,再吃尽一个G的swap;

-Xss:每个线程的Stack大小;

-verbose:gc:现实垃圾收集信息;

-Xloggc:gc.log:指定垃圾收集日志文件;

-Xmn:young:generation的heap大小,一般设置为Xmx的3、4分之一;

-XX:+UseParNewGC:缩短minor收集的时间;

-XX:+UseConcMarkSweepGC:缩短major收集的时间;

3、tomcat多实例访问:

(1)tomcat的并发访问数约为700-800,所以一个tomcat就是一个站点,不会再配置多余的虚拟主机,增加并发访问量的方法是通过

tomcat多实例来实现的,常用的负载均衡架构是nginx+tomcat(多实例),所有tomcat都使用统一的站点目录;

(2)一个tomcat实例只能使用一个zabbix监控端口(默认12345),具体监控参见"9.4、安装zabbix"监控tomcat小节;

(3)tomcat多实例内存分配原则:

列如:8核8G内存的服务器跑4个tomcat实例:

分配原则:服务器自留2G的内存,然后每个tomcat分jvm分配1.5G;

(4)tomcat本身是好的,有垃圾回收机制,但是挡不住代码烂,结果就是会导致tomcat内存占用量一直升高,得不到释放,导致程序

访问变慢,解决的方法是改代码(可能性小)或重启tomcat服务(可以做定时任务,在夜里定时重启tomcat服务,需要注意的是多实例不能

同时重启,要一个一个的去重启)

4、访问:

(1)tomcat默认启动监听的是8080端口,监听所有的网卡,在连接器组件中可以更改监听的IP地址;

(2)一个appBase="webapps"目录下可以放置多个web应用,根据不同的web应用名进行区分访问,也可以直接指定appBase的路径(相对和绝对路径都可),

也可以通过Context组件设置默认访问的服务;

(3)一台服务器可以部署多个tomcat服务,是靠端口号进行区分的,需要改变的是conf/service.xml文件的两个端口号停止1、访问1个端口);

5、使用"show-busy-java-threads.sh"脚本监控tomcat的cpu使用率:

"show-busy-java-threads.sh"脚本用于快速排查Java的CPU性能问题(top us值过高),自动查出运行的Java进程中消耗CPU多的线程,并打印出

其线程栈,从而确定导致性能问题的方法调用,目前只支持Linux,"https://github.com/oldratlee/useful-scripts"网站有比较详细的使用细则;

(1)下载脚本:

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

[root@slave-node1 tools]# git clone https://github.com/oldratlee/useful-scripts.git

(2)使用脚本:

[root@slave-node1 tools]# sh useful-scripts/show-busy-java-threads.sh

[1] Busy(1.9%) thread(1302/0x516) stack of java process(1037) under user(zabbix):

"VM Periodic Task Thread" os_prio=0 tid=0x00007f801c14a800 nid=0x516 waiting on condition


[2] Busy(0.0%) thread(1037/0x40d) stack of java process(1037) under user(zabbix):


[3] Busy(0.0%) thread(1117/0x45d) stack of java process(1037) under user(zabbix):

"main" #1 prio=5 os_prio=0 tid=0x00007f801c04b800 nid=0x45d runnable [0x00007f802654b000]

java.lang.Thread.State: RUNNABLE

at java.net.PlainSocketImpl.socketAccept(Native Method)

at java.net.AbstractPlainSocketImpl.accept(AbstractPlainSocketImpl.java:409)

at java.net.ServerSocket.implAccept(ServerSocket.java:545)

at java.net.ServerSocket.accept(ServerSocket.java:513)

at com.zabbix.gateway.JavaGateway.main(JavaGateway.java:80)


[4] Busy(0.0%) thread(1230/0x4ce) stack of java process(1037) under user(zabbix):

"GC task thread#0 (ParallelGC)" os_prio=0 tid=0x00007f801c05e800 nid=0x4ce runnable


[5] Busy(0.0%) thread(1231/0x4cf) stack of java process(1037) under user(zabbix):

"GC task thread#1 (ParallelGC)" os_prio=0 tid=0x00007f801c060000 nid=0x4cf runnable


6、补充:单独配置Nginx的tomcat动态网站环境:

[root@nginx conf.d]# cat jsp.conf

server {

server_name localhost;

listen 80;

location / {

#root /soft/code;

try_files $uri @java_page;

#index index.jsp index.html;

}

location @java_page{

proxy_pass http://192.168.56.20:8080;

}

}











posted @ 2020-02-17 11:49  云起时。  阅读(484)  评论(0编辑  收藏  举报