Tomcat部署及优化
tomcat
tomcat介绍
- 免费的、开放源代码的Web应用服务器
- Apache软件基金会(Apache Software Foundation)Jakarta项目中的一个核心项目
- 由Apache、Sun和一些公司及个人共同开发而成
- 深受Java爱好者的喜爱,并得到部分软件开发商的认可
- 目前比较流行的Web应用服务器
tomcat核心组件
tomcat处理请求过程
- server:tomcat实例 注意:一个JVM(java虚拟机)只能由一个tomcat实例;
- service:接收请求到处理请求的所有组件集合。service组件分为connector(连接器)和 container(容器)两部分;
- connector负责接受用户请求和消息报文的,将消息报文发往cotainer;
- container是容器对外映射的接口,用于封闭和管理servlet;
- engine:是一个容器,是用来将用户的请求发往它下面的虚拟主机的,engine是加载虚拟主机的一个容器;
- host:是虚拟主机的容器;
- content:管理servlet;
- servlet:是管理java语言的组件
用法实例
-
用户在浏览器中输入网址localhost:8080/ test/index. jsp, 请求被发送到本机端口8080, 被在那里监听的Coyote HTTP/1.1 Connector获得;
-
Connector 把该请求交给它所在的Service 的Engine (Container) 来处理,并等待Engine 的回应;
-
Engine 获得请求localhost/test/ index. jsp, 匹配所有的虚拟主机Host;
-
Engine 匹配到名为localhost 的Host (即使匹配不到也把请求交给该Host 处理,因为该Host被定义为该Engine的默认主机),名为localhost的Host获得请求/test/ index. jsp, 匹配它所拥有的所有Context。 Host 匹配到路径为/test 的Context (如果匹配不到就把该请求交给路径名为“”的Context去处理
-
path=“/test”的Context 获得请求/ index. jsp, 在它的mapping table中寻找出对应的Servlet。Context 匹配到URL Pattern 为*. jsp 的Servlet, 对应于JspServlet类;
-
构造HttpServletRequest 对象和HttpServletResponse 对象,作为参数调用JspServlet的doGet ()或doPost(),执行业务逻辑、数据存储等;
-
Context把执行完之后的HttpServletResponse对象返回给Host;
-
Hos t把Ht tpServl etResponse对象返回给Engine;
-
Engine把Ht tpServletResponse对象返回Connector;
-
Connector把HttpServletResponse 对象返回给客户Browser。
Tomcat 安装部署
配置安装Tomcat流程
添加压缩安装包并解压
[root@server1 ~]# ls -lh
[root@server1 ~]# tar zvxf jdk-8u91-linux-x64.tar.gz
[root@server1 ~]# mv jdk1.8.0_91/ /usr/local/java
[root@server1 ~]# cd /usr/local/java/
[root@server1 java]# ls -lh
配置Java环境
设置环境变量
[root@server1 ~]# vi /etc/profile
[root@server1 ~]# source /etc/profile 将java脚本导入到环境变量使其生效
[root@server1 ~]# echo $PATH
添加
export JAVA_HOME=/usr/local/java 定义变量,设为全局变量
export JAVA_JRE=/usr/local/java/jre
export PATH=$PATH:$JAVA_HOME/bin:$JAVA_HOME/lib:$JAVA_JRE/bin:$JAVA_JRE/lib #环境变量
查看版本
配置java脚本
测试java是否正常运行
[root@server1 ~]# vi abc.java
[root@server1 ~]# javac abc.java
[root@server1 ~]# java abc
public class abc {
public static void main (String[] args) {
System.out.println ("hello world!!!!!!!!!");
}
}
测试完成
解压缩Tomcat
[root@server1 ~]# tar zvxf apache-tomcat-8.5.16.tar.gz
[root@server1 ~]# mv apache-tomcat-8.5.16 /usr/local/tomcat8
[root@server1 ~]# cd /usr/local/tomcat8/
查看tomcat启动
[root@server1 ~]# cd /usr/local/tomcat8/
[root@server1 tomcat8]# ls -lh
[root@server1 tomcat8]# cd bin/
[root@server1 bin]# ls -lh
[root@server1 bin]# vi startup.sh #启动脚本
[root@server1 bin]# vi shutdown.sh # 关闭脚本
创建软链接
[root@server1 ~]# ln -s /usr/local/tomcat8/bin/startup.sh /usr/bin/tomcatup
[root@server1 ~]# ln -s /usr/local/tomcat8/bin/shutdown.sh /usr/bin/tomcatdown
[root@server1 ~]# tomcatup # 服务启动
[root@server1 ~]# netstat -anpt | grep 8080
创建测试页
[root@server1 ~]# mkdir -pv /web/app1
[root@server1 ~]# mkdir -p /web/app2
[root@server1 ~]# vi /web/app1/index.jsp
添加
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
<html>
<head>JSP Web 1</head>
<body>
<% out.println("this is web1,Welcome!!!");%>
<div>动态页面</div><br/><img src="1.jpg" />
</body>
</html>
[root@server1 ~]# cd /web/app1
创建连接
[root@server1 ~]# vi /usr/local/tomcat8/conf/server.xml
[root@server1 ~]# tomcatdown 服务关闭
[root@server1 ~]# tomcatup 服务重启
[root@server1 ~]# netstat -anpt | grep 8080 查看端口状态
添加
<Context docBase="/web/app1" path="" reloadable="false">
</Context>
访问20.0.0.13:8080
Tomcat本地访问通过域名可访问
配置文件
[root@server1 ~]# vi /usr/local/tomcat8/conf/server.xml
[root@server1 ~]# tomcatdown
[root@server1 ~]# tomcatup
[root@server1 ~]# netstat -anpt | grep 8080
在客户机上
添加映射记录
在浏览器上访问
www.aa.com:8080
虚拟主机配置
- 有多个项目同时运行时,一台服务器不建议运行多个Tomcat服务,需要配置虚拟主机
- 通过两个域名访问到不同的项目内容
- 步骤
- 创建www和bbs项目目录和文件
- 修改Tomcat主配置文件
- 重启Tomcat服务
- 访问测试
Connector容器结束方式
<Connector> 或 <Connector> ... --/>
...
</Connector>
tomcat虚拟主机
基于域名的虚拟主机和基于端口的虚拟主机
基于域名
在已存在的组件中增加一个新的容器配置
基于域名
添加一个新的容器配置
[root@server1 ~]# vi /usr/local/tomcat8/conf/server.xml
<Host name="www.ab.com" appBase="webapps"
unpackWARs="true" autoDeploy="true">
<Context docBase="/web/app2" path="" reloadable="false">
</Context>
</Host>
修改配置app2的页面
在另一台客户机上添加映射
vi /etc/hosts
访问测试
www.ab.com
基于端口
创建组件及里面的各个组件
先删除上一个添加的配置
后添加下图的配置
[root@server1 ~]# vi /usr/local/tomcat8/conf/server.xml
<Service name="Catalina2">
<Connector port="8090" protocol="HTTP/1.1" connectionTimeout="20000" redirectPort="8443"/>
<Engine name="Catalina2" defaultHost="localhost">
<Host name="www.ab.com" appBase="webapps" unpackWARs="true" autoDeploy="true">
<Context docBase="/web/app2" path="" reloadable="false">
</Context>
</Host>
</Engine>
</Service>
[root@server1 ~]# tomcatdown
[root@server1 ~]# tomcatup
[root@server1 ~]# netstat -anpt | grep java
[root@server1 ~]# netstat -anpt | grep 8090
[root@server1 ~]# netstat -anpt | grep 8080
访问测试
www.aa.com:8080
访问测试
www.ab.com:8090
Tomcat优化
- 操作系统优化(内核参数优化)
- Tomcat配置文件参数优化
- Java虚拟机(JVM)调优
Tomcat配置文件参数优化
- Tomcat主配置文件server.xml常用的配置参数
- Tomcat配置文件参数优化
-
maxThreads: Tomcat 使用线程来处理接收的每个请求,这个值表示Tomcat 可创建的 最大的线程数,默认值是200。
-
minSpareThreads: 最小空闲线程数,Tomcat 启动时的初始化线程数,表示即使没有人使用也开这么多空线程等待,默认值是10。
-
maxSpareThreads: 最大备用线程数,一旦创建的线程超过这个值,Tomcat就会关闭不再需要的socket 线程。默认值是 -1 (无限制),一般不需要指定。
-
URIEncoding: 指定Tomcat 容器的URL编码格式,Tomcat 语言编码格式这块不如其它Web 服务器软件配置方便,需要分别指定。
-
connnectionTimeout: 网络连接超时,单位:毫秒,设置为0表示永不超时,这样设置有隐患的。通常默认20000毫秒(20秒)就可以。
-
enableLookups: 是否反查域名,以返回远程主机的主机名,取值为: true 或false,如果设置为false,则直接返回IP地址,为了提高处理能力,应设置为false。
-
disableUploadTimeout:上传时是否使用超时机制。应设置为true。
-
connectionUploadTimeout:上传超时时间,毕竟文件上传可能需要消耗更多的时间,该参数需要根据自己的业务需要自行调整,以使Servlet 有较长的时间来完成它的执行,需要与上一个参数一起配合使用才会生效。
-
acceptCount:指定当所有可以使用的处理请求的线程都被使用时,可传入连接请求的最大队列长度,超过这个数的请求将不予处理,默认为100个。
-
compression: 是否对响应的数据进行GZIP 压缩,off表示禁止压缩、on表示允许压缩(文本将被压缩)、force 表示所有情况下都进行压缩,默认值为off。压缩数据后可以有效的减少页面的大小,一般可以减小1/3 左右,因而节省带宽。
-
compressionMinSize: 表示压缩响应的最小值,只有当响应报文大小大于这个值的时候才会对报文进行压缩,如果开启了压缩功能,默认值就是2048。(1k)
-
compressableMimeType:压缩类型,指定对哪些类型的文件进行数据压缩。
-
noCompressionUserAgents=” gozilla, traviata": 对于以下的浏览器,不启用压缩
-
配置优化
修改添加配置
[root@server1 ~]# vi /usr/local/tomcat8/conf/server.xml
添加 maxThreads="300" minSpareThreads="10" maxSpareThreds="20" />
URIEncoding="UTF-8"
connectionTimeout="20000“(20秒) enablelookups="false" connectionUploadTimeout="15000"