Tomcat服务器的部署和优化
文章目录1.什么是Tomcat2.tomcat顶层架构3.Tomcat请求过程4.Tomcat安装过程5.tomcat服务优化1.什么是Tomcat它是一款免费的,开源的web应用服务器,是Apache软件基金会(Apache Software Foundation)Jakarta项目中的一个核心项目由Apache、Sun和一些公司及个人共同开发而成,深受Java爱好者的喜爱,并得到部分软件开发商
1.什么是Tomcat
它是一款免费的,开源的web应用服务器,是Apache软件基金会(Apache Software Foundation)Jakarta项目中的一个核心项目
由Apache、Sun和一些公司及个人共同开发而成,深受Java爱好者的喜爱,并得到部分软件开发商的认可,是目前比较流行的web应用服务器
Tomcat虽然和Apache或nginx这些web服务器一样,具有处理html页面的功能,然而由于其处理静态html的能力远不及Apache或者Nginx,所以Tomcat通常是作为一个Servlet和JSP容器,单独运行在后端。
Tomcat由一系列的组件构成,其中核心的组件有三:
- web容器:完成web服务器的功能
- Servlet容器:名字为catalina,用于处理Servlet代码
- 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 的参数属性值,可以参考官方文档的详细说明进行学习。
开放原子开发者工作坊旨在鼓励更多人参与开源活动,与志同道合的开发者们相互交流开发经验、分享开发心得、获取前沿技术趋势。工作坊有多种形式的开发者活动,如meetup、训练营等,主打技术交流,干货满满,真诚地邀请各位开发者共同参与!
更多推荐
所有评论(0)