Tomcat服务的部署和优化

目录

一、Tomcat

二、tomcat结构 

三、在centos7上部署tomcat

1、安装所需环境 

2、安装tomcat

3、启动tomcat

四、tomcat优化

1、tomcat启动速度优化

2、tomcat虚拟主机

 3、Tomcat配置文件参数优化


一、Tomcat

Tomcat 是 Java 语言开发的,Tomcat 服务器是一个免费的开放源代码的 Web 应用服务器,是 Apache 软件基金会的 Jakarta 项目中的一个核心项目,由 Apache、Sun 和其他一些公司及个人共同开发而成。
Tomcat 属于轻量级应用服务器,在中小型系统和并发访问用户不是很多的场合下被普遍使用,是开发和调试 JSP 程序的首选。一般来说,Tomcat 虽然和 Apache 或者 Nginx 这些 Web 服务器一样,具有处理 HTML 页面的功能,然而由于其处理静态 HTML 的能力远不及 Apache 或者 Nginx,所以 Tomcat 通常是作为一个 Servlet 和 JSP 容器,单独运行在后端。

Java Servlet ,可以理解为是一个服务连接器,是用 Java 编写的服务器端程序,具有独立于平台和协议的特性, 简单的理解:servlet 就是一个中间件,包含了接口和方法,将客户端和数据库连接,从而实现动态网页的创建。

Java Server Pages,是一种动态网页开发技术。它使用 JSP 标签在HTML网页中插入 Java 代码。标签通常以 <% 开头,以 %> 结束。
JSP 是一种 Java servlet,主要用于实现 Java web 应用程序的用户界面部分。
JSP 通过网页表单获取用户输入数据、访问数据库及其他数据源,然后动态地创建网页。

二、tomcat结构 

核心的组件有三个:

  1. Web 容器:完成 Web 服务器的功能。

  2. Servlet 容器:名字为 catalina,用于处理 Servlet 代码。

  3. JSP 容器:用于将 JSP 动态网页翻译成 Servlet 代码

名称说明
server Tomcat运行的进程实例,一个Server中可以有多个service,通常就一个
service用来组织Engine和Connector的对应关系,一个service中只有一个Engine
connector负责客户端的HTTP、HTTPS、AJP等协议连接。一个Connector只属于某一个Engine
Engine用来响应并处理用户请求。一个Engine上可以绑定多个Connector
Host可以实现多虚拟主机,例如使用不同的主机头区分
Context配置特定url路径映射和目录的映射关系: url => directory
Wrapper每一Wrapper封装着 一个Servlet

tomcat请求过程:

1、用户通过浏览器的网址+80端口想Nginx发出请求,然后通过Nginx的反向代理将请求发送到本机的8080端口,被监听的Connector(Coyote前端页面和HTTP/1.1协议)来获得。Connector把该请求交给他所在的Service的Engine(Container)来处理,并等待Engine回应(此时为Web容器操作);
2、Engine相应请求并分发给不同的虚拟主机也就是Host站点,站点确认后调用Context确定相应的URL路径来找到index.jsp文件,将其中的JAVA代码翻译成Servlet代码,之后通过Wrapper封装给Servlet容器(此时为JSP容器操作),最后再Servlet容器中,通过Catalina脚本来执行代码,并将执行结果封装成HttpServletResponse对象返回给Context中(Servlet容器作用);
3、执行完之后的请求相应在Context、Host、Engine容器之间逐层返回,最后再将数据返回给Connector后再返回给用户所使用的就客户端。

三、在centos7上部署tomcat

systemctl stop firewalld
setenforce 0

#所需资源如下
apache-tomcat-9.0.16.tar.gz 
jdk-8u201-linux-x64.rpm
 
#安装JDK
rpm -ivh jdk-8u201-linux-x64.rpm 

1、安装所需环境 

1. #修改配置文件
vim /etc/profile
 
export JAVA_HOME=/usr/java/jdk1.8.0_201-amd64
export CLASSPATH=$JAVA_HOME/lib/tools.jar:$JAVA_HOME/lib/dt.jar
export PATH=$JAVA_HOME/bin:$PATH
 
2. #刷新配置文件
source /etc/profile

2、安装tomcat

1.,解压tomcat包
tar -zxf apache-tomcat-9.0.16.tar.gz 
 
2. #将解压后的包拷贝至/usr/local/下
cp -r apache-tomcat-9.0.16 /usr/local/tomcat

3、启动tomcat

1. #进入tomcat目录下的bin/startup.sh
cd /usr/local/tomcat/
/usr/local/tomcat/bin/startup.sh
 
2. #看是否启动成功
ss -natp |grep 8080

 开启成功

四、tomcat优化

1、tomcat启动速度优化

vim /usr/java/jdk1.8.0_201-amd64/jre/lib/security/java.security
--117行--修改
securerandom.source=file:/dev/urandom

/dev/urandom是/dev/random的非阻塞版本,/dev/random的random pool依赖于系统中断因此在系统的中断数不足时,/dev/random设备会一直封锁,尝试读取的进程就会进入等待状态,直到系统的中断数充分够用,/dev/random设备可以保证数据的随机性。

/dev/urandom不依赖系统的中断,也就不会造成进程忙等待,但是数据的随机性也不高,所以该随机数的安全性理论上不高。如果应用对安全性要求很高,那么应该使用/dev/random。
 

2、tomcat虚拟主机

与前面学习的nginx一样,一台服务器不可能只跑一个业务的,在tomcat上,也有虚拟主机的设置。

1. 创建 A 和 B 项目目录和文件

cd /usr/local/tomcat/webapps
mkdir A B

2. 创建文件

echo "HI!! 192.168.116.120 " > A/index.html
echo "HI!! 192.168.116.120 " > B/index.html

3. 修改主配置文件

vim /usr/local/tomcat/conf/server.xml 


  </Host>
 
        <Host name="www.A.com"  appBase="/usr/local/tomcat/webapps" unpackWARs="true" autoDeploy="true"
              xmlValidation="false" xmlNamespaceAware="false">
              <Context docBase="/usr/local/tomcat/webapps/A"
                path="" reloadable="true" />
     </Host>
        <Host name="www.B.com"  appBase="/usr/local/tomcat/webapps" unpackWARs="true" autoDeploy="true"
              xmlValidation="false" xmlNamespaceAware="false">
              <Context docBase="/usr/local/tomcat/webapps/B"
                path="" reloadable="true" />
     </Host>

4. 重启服务

systemctl restart tomcat

5. 再开启一台centos虚拟机,更改host文件

192.168.116.23  www.A.com  www.B.com

6. 在这一台centos虚拟机的浏览器中测试
分别输入www.A.com www.B.com

 

 3、Tomcat配置文件参数优化

Tomcat默认安装下的缺省配置并不适合生产环境,它可能会频繁出现假死现象需要重启,只有通过不断压测优化才能让它最高效率稳定的运行。优化主要包括三方面,分别为操作系统优化(内核参数优化),Tomcat配置文件参数优化,Java虚拟机(JVM)调优。

常用的优化相关参数如下:
【redirectPort】如果某连接器支持的协议是HTTP,当接收客户端发来的HTTPS请求时,则转发至此属性定义的端口。
 
【maxThreads】Tomcat使用线程来处理接收的每个请求,这个值表示Tomcat可创建的最大的线程数,即支持的最大并发连接数,默认值是 200。
 
【minSpareThreads】最小空闲线程数,Tomcat 启动时的初始化的线程数,表示即使没有人使用也开这么多空线程等待,默认值是 10。
 
【maxSpareThreads】最大备用线程数,一旦创建的线程超过这个值,Tomcat就会关闭不再需要的socket线程。默认值是-1(无限制)。一般不需要指定。
 
【URIEncoding】指定 Tomcat 容器的 URL 编码格式,语言编码格式这块倒不如其它 Web服务器软件配置方便,需要分别指定。
 
【connnectionTimeout】网络连接超时,单位:毫秒,设置为 0 表示永不超时,这样设置有隐患的。通常默认 20000 毫秒就可以。
 
【enableLookups】是否反查域名,以返回远程主机的主机名,取值为:true 或 false,如果设置为 false,则直接返回 IP 地址,为了提高处理能力,应设置为 false。
 
【disableUploadTimeout】上传时是否使用超时机制。应设置为 true。
 
【connectionUploadTimeout】上传超时时间,毕竟文件上传可能需要消耗更多的时间,这个根据你自己的业务需要自己调,以使Servlet有较长的时间来完成它的执行,需要与上一个参数一起配合使用才会生效。
 
【acceptCount】指定当所有可以使用的处理请求的线程数都被使用时,可传入连接请求的最大队列长度,超过这个数的请求将不予处理,默认为 100 个。
 
【compression】是否对响应的数据进行GZIP压缩,off:表示禁止压缩;on:表示允许压缩(文本将被压缩)、force:表示所有情况下都进行压缩,默认值为 off,压缩数据后可以有效的减少页面的大小,一般可以减小 1/3 左右,节省带宽。
 
【compressionMinSize】表示压缩响应的最小值,只有当响应报文大小大于这个值的时候才会对报文进行压缩,如果开启了压缩功能,默认值就是 2048。
 
【compressableMimeType】压缩类型,指定对哪些类型的文件进行数据压缩。
 
【noCompressionUserAgents="gozilla, traviata"】对于以下的浏览器,不启用压缩

 以上是一些常用的配置参数,还有好多其它的参数设置,还可以继续深入的优化,HTTP Connector 与 AJP Connector 的参数属性值。下 面 开 始 对 Tomcat 配置文件优化进行前后的对比。

vim /usr/local/tomcat/conf/server.xml
......
<Connector port="8080" protocol="HTTP/11.1" 
           connectionTimeout="20000" 
           redirectPort="8443" 
           --71行--插入
           minSpareThreads="50" 
           enableLookups="false" 
           disableUploadTimeout="true" 
           acceptCount="300" 
           maxThreads="500" 
           processorCache="500"
           URIEncoding="UTF-8" 
           compression="on" 
           compressionMinSize="2048" 
compressableMimeType="text/html,text/xml,text/javascript,text/css,text/plain,image/gif,image /jpg,image/png"/>

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值