Tomcat服务器的部署和优化

1.什么是Tomcat

它是一款免费的,开源的web应用服务器,是Apache软件基金会(Apache Software Foundation)Jakarta项目中的一个核心项目
由Apache、Sun和一些公司及个人共同开发而成,深受Java爱好者的喜爱,并得到部分软件开发商的认可,是目前比较流行的web应用服务器

Tomcat虽然和Apache或nginx这些web服务器一样,具有处理html页面的功能,然而由于其处理静态html的能力远不及Apache或者Nginx,所以Tomcat通常是作为一个Servlet和JSP容器,单独运行在后端。

Tomcat由一系列的组件构成,其中核心的组件有三:

  1. web容器:完成web服务器的功能
  2. Servlet容器:名字为catalina,用于处理Servlet代码
  3. JSP容器:用于将JSP动态网页翻译成Servelt代码

在这里插入图片描述

  • Java servlet 是 运行在web服务器或应用程序服务器上的程序,它是作为来自web浏览器或其他Http客户端的请求和Http服务器上的数据库或应用程序之间的中间层。使用Servlet,可以收集来自网页表单的用户输入,呈现来自数据库或者其他源的记录,还可以动态创建网页,与CGI(公共网关接口)功能类似。
    (相当于和php一样)

  • Jsp全称Java Server Pages,是一种动态网页开发技术。它使用JSP 标签在HTML网页中插入Java代码。标签通常以‘<%’开头,‘%>’结束。

JSP是一种Java servlet,主要用于实现Java web应用程序的用户界面部分。
JSP通过网页表单获取用户输入数据、访问数据库及其他数据库,然后动态地创建网页。

2.tomcat顶层架构

1.Tomcat中最顶层的容器是server,代表着整个服务器,一个Server可以包含至少一个Service,用于具体提供服务。
2.Service主要包含两个部分:Connector和Container。Tomcat的心脏就是这两个组件,这两个组件的作用:Connector用于处理连接相关的事情,并提供Socket与Request和Response相关的转化;Container用于封装和管理Servlet,以及具体处理Request请求。
3.一个Tomcat中只有一个Server,一个Server可以包含多个Services,一个Service只有一个Contaner,但是可以有多个Connectors,因为一个服务可以有多个连接,如同时提供Http和Https链接,也可以提供向相同协议不同端口的连接。
4.多个Connector和一个Container就形成了一个Service,有了Service就可以提供服务了,但是Service需要一个生存环境,那就是Server,所以整个Tomcat的生命周期由Server控制。上述父子关系都可以在tomcat的conf目录下的server.xml配置文件中看出。
5.server.xml中定义< Server port= “8005” shutdown=“shutdown”>
这会让Tonmcat启动一个server实列(JVM),它监听在8005端口以接收“shutdown”命令,如果接收到了,就会关闭Tomcat。各Server的定义不能使用同一个端口,这意味着如果在同一个物理机上启动了多个server实例,必须配置他们使用不同的端口。

在这里插入图片描述
也就是说:

  • service:对外提供web服务
  • connector(连接器):负责接手和响应外部请求
  • container(容器):负责处理请求的容器,处理内部业务事务

Container用于封装和管理Servlet,以及处理Request请求,在Container内部包含了4个子容器。
Engine:引擎,管理多个虚拟主机
Host:虚拟主机,负责web应用的部署
Context:web应用,包含多个Servlet
Wrapper:每一个Wrapper封装着一个servlet,负责实例的创建、执行和销毁功能

3.Tomcat请求过程

在这里插入图片描述
可看成Connector和Container容器的处理过程,最终处理的是由Servlet处理再响应回去。

1.connector 接收用户请求
2.connector 发送给container 的engine
3.Engine Host Context Wrapper 这四个容器之间层层调用,最后再servlet中执行对应的业务逻辑
4.处理完毕后再层层返回,交给connector响应发送给用户。

4.Tomcat安装过程

先关闭防火墙
在这里插入图片描述
然后把需要安装的环境包拖进来:
在这里插入图片描述

在这里插入图片描述
rpm命令进行安装(注意我用的jdk是rpm包,不是tar包)

安装好后查看java,发现还不是我们要安装的版本怎么办?
在这里插入图片描述
需要设置相关的环境变量:

可以修改/etc/profile/
在末行输入
export JAVA_HOME=(java目录)

在这里插入图片描述

Java目录可以通过java -qpl jdk(你的包名)查看

在这里插入图片描述
在这里插入图片描述
关于编译目录在java安装目录下的lib文件夹内

lib目录下有两个文件:
dt.jar:是关于运行环境的类库,主要是可视化的swing的包。
tools.jar:主要是一些jdk工具的类库,包括javac,java,javap(jdk自带的一个反编译工具),javadoc等。

上面的CLASSPATH:编译,运行java程序时,JRE会去该变量指定的路径中搜索所需的类(.class)文件。
JRE:java运行时环境。
JDK:java开发工具。
JVM:Java虚拟机,是java程序可以在多种平台上运行class文件。

接下来还没完,要设置系统变量,使java变量能被系统识别
一般在java安装目录下的bin目录中:
在这里插入图片描述
现在查看未安装前的,也就是原来的java目录
在这里插入图片描述
当我们刷新一下刚刚编译的文件后
在这里插入图片描述
在这里插入图片描述

在看看环境变量
在这里插入图片描述

ok,java设置完了
验证一下,通过java写个hello world

vim test.java #创建新java文件

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
ok

接下来我们就是安装tomcat了
在这里插入图片描述在这里插入图片描述

后台启动tomcat命令:
/usr/local/tomcat/bin/startup.sh

/usr/local/tomcat/bin/catalina.sh start

前台启动tomcat命令:
/usr/local/tomcat/bin/catalina.sh run

查看端口:
netstat -natp | grep 8080

在这里插入图片描述

在这里插入图片描述
同时在bin目录下还有个shutdown.sh,运行它就停止tomcat了

在这里插入图片描述
在这里插入图片描述

/dev/urandom是/dev/random的非阻塞版本,即当熵池中没有可取的随机数时,读取/dev/urandom设备仍然会返回一个随机数,只是该随机数的安全性理论上不高。如果应用对安全性要求很高,那么应该使用/dev/random。

5.tomcat服务优化

很多时候公司会有多个项目需要运行,那么肯定不可能是一台服务器上运行多个tomcat服务
那么就需要tomcat虚拟主机来帮忙了

比方说我要通过两个不同的域名,访问到不同网站

设置ETC域名为www.etc.com
设置BTC域名为www.btc.com

创建ETC和BTC项目目录和文件


然后修改主配置文件
vim /usr/local/tomcat/conf/server.xml

在164行< host >后插入

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

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

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

参数解释
【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 的参数属性值,可以参考官方文档的详细说明进行学习。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值