来源:https://www.cnblogs.com/L-Test/p/10611126.html
一、下载地址
https://tomcat.apache.org/download-80.cgi

二、安装步骤
将安装包 apache-tomcat-8.5.39.tar.gz 上传至做事器 /usr/local 目录下,再实行如下步骤:
[root@admin local]# cd /usr/local[root@admin local]# tar -zxvf apache-tomcat-8.5.39.tar.gz // 解压压缩包[root@admin local]# mv apache-tomcat-8.5.39 tomcat-8.5.39 // 重命名tomcat目录
启动tomcat(JDK已经安装好并配置了环境变量):
[root@admin local]# cd ./tomcat-8.5.39/bin[root@admin bin]# ./startup.sh // 启动tomcat
启动成功,如下图:
三、监控
通过以下网址打开tomcat管理页面,默认端口为8080(如果不能打开则关闭做事器防火墙或者开放8080端口)
右侧的 Server Status Manager APP 和 Host Manager代表tomcat的管理页面,想要进入这三个页面首先须要配置做事器上tomcat安装目录下的conf/tomcat-users.xml文件,如果不做配置则会返回403页面,如下:
在conf/tomcat-users.xml添加如下配置,再重启tomcat
<rolerolename="admin"/><rolerolename="admin-gui"/><rolerolename="admin-script"/><rolerolename="manager-gui"/><rolerolename="manager-script"/><rolerolename="manager-jmx"/><rolerolename="manager-status"/><userusername="admin"password="admin"roles="admin,admin-gui,admin-script,manager-gui,manager-script,manager-jmx,manager-status"/>
Tomcat8如果在上面配置的根本上,访问时会报403缺点,以是须要修正conf/Catalina/localhost/manager.xml 文件(如果没有的话新建)。配置内容如下:
<Context privileged="true"antiResourceLocking="false"docBase="${catalina.home}/webapps/manager"><ValveclassName="org.apache.catalina.valves.RemoteAddrValve"allow="^.$"/></Context>
再次重启tomcat后,就能进入Server Status Manager APP 和 Host Manager这三个页面了。
Server Status
Status-JVM
Free memory:剩余内存;Total menory:总内存;Max menory:最大内存;
Status-HTTP
Max threads:最大线程数; Current thread count:当前哨程数; Current thread busy:当前劳碌线程数; Max processing time:最大处理韶光; ms Processing time:最短处理韶光; Request count:要求数; Error count:缺点数; Bytes received:接管字节; Bytes sent:发送字节;
Manager APP
该页面用来管理Web项目,支配在Tomcat下的项目可以通过该页面来管理,如下:
Host Manager
该页面用于管理主机
四、调优
1、Tomcat的运行模式有三种:
BIO
性能比较低下,没有经由任何优化处理和支持。一个线程处理一个要求。缺陷:并发量高时,线程数较多,摧残浪费蹂躏资源。Tomcat7或以下,在Linux系统中默认利用这种办法。
NIO
nio(new I/O),是Java SE 1.4及后续版本供应的一种新的I/O操作办法(即java.nio包及其子包)。Java nio是一个基于缓冲区、并能供应非壅塞I/O操作的Java API,因此nio也被算作是non-blocking I/O的缩写。它拥有比传统I/O操作(bio)更好的并发运行性能。
利用Java的异步IO处理,可以通过少量的线程处理大量的要求。
Tomcat8在Linux系统中默认利用这种办法。
Tomcat7必须修正Connector配置来启动:
<Connectorport="8080"protocol="org.apache.coyote.http11.Http11NioProtocol"connectionTimeout="20000"redirectPort="8443"/>
APR
安装起来最困难,但是从操作系统级别来办理异步的IO问题,能够大幅度的提高性能。即Apache PortableRuntime,从操作系统层面办理IO壅塞问题。
Tomcat7或Tomcat8在Win7或以上的系统中启动默认利用这种办法。
Linux如果安装了apr和native,Tomcat直接启动就支持apr。
详细安装办法 拜会这个地址:https://my.oschina.net/lsw90/blog/181161
Tomcat启动的时候,可以通过log看到Connector利用的是哪一种运行模式:
StartingProtocolHandler["http-bio-8080"]StartingProtocolHandler ["http-nio-8080"]StartingProtocolHandler ["http-apr-8080"]
Tomcat7及以下版本启动启动NIO模式:
修正server.xml里的Connector节点,修正protocol为:org.apache.coyote.http11.Http11NioProtocol,如下:
修正前:
修正后:
为什么它不直接改成NIO的形式呢?
这个办法是利用了jdk 1.4及后续版本供应的一种新的I/O操作办法(即java.nio包及其子包)为桥梁实现的,不改成这种优化办法便是为了兼容1.4之前的JAVA项目也能跑起来。
2、线程池(实行器)
Connector节点:
官方文档:https://tomcat.apache.org/tomcat-8.5-doc/config/http.html
默认的tomcat没有启用线程池,在tomcat中每一个用户要求都是一个线程,以是可以利用线程池提高性能。这里前台实在有一个调度线程,然后调度线程会放入线程池内,然后到到一定的时候线程池的任务变成事情线程。
开启线程池:
maxThreads配置为500,但显示为-1,查询官方文档创造:
意思是该属性配置处理并发要求的最大线程数,如果不配置默认值是200。如果配置了executor属性,这个属性会被忽略。把稳斜体部分提到:如果executor设置了值,利用JMX查看的时候这个值会是-1,这是正常的。
详细参数阐明如下:
将原有的Executor标签内容更换成如下内容
<Executorname="tomcatThreadPool"--线程池名namePrefix="catalina-exec-"maxThreads="500"minSpareThreads="30"maxIdleTime="60000"prestartminSpareThreads="true"maxQueueSize="100"/>
将原有的Connector标签内容更换成如下内容
更换后访问速率肯定会比以前快
protocol:Tomcat 8 设置 nio2 更好:org.apache.coyote.http11.Http11Nio2Protocolprotocol:Tomcat 6 设置 nio 更好:org.apache.coyote.http11.Http11NioProtocolprotocol:Tomcat 8 设置 APR 性能飞快:org.apache.coyote.http11.Http11AprProtocolconnectionTimeout:Connector接管一个连接后等待的韶光(milliseconds),默认值是60000。maxConnections:这个值表示最多可以有多少个socket连接到tomcat上enableLookups:禁用DNS查询acceptCount:当tomcat起动的线程数达到最大时,接管排队的要求个数,默认值为100。maxPostSize:设置由容器解析的URL参数的最大长度,-1(小于0)为禁用这个属性,默认为2097152(2M) 请把稳, FailedRequestFilter 过滤器可以用来谢绝达到了极限值的要求。maxHttpHeaderSize:http要求头信息的最大程度,超过此长度的部分不予处理。一样平常8K。compression:是否启用GZIP压缩 on为启用(文本数据压缩) off为不启用, force 压缩所有数据disableUploadTimeout:这个标志许可servlet容器利用一个不同的,常日长在数据上传连接超时。 如果不指定,这个属性被设置为true,表示禁用该韶光超时。compressionMinSize:当超过最小数据大小才进行压缩acceptorThreadCount:用于接管连接的线程数量。增加这个值在多CPU的机器上,只管你永久不会真正须要超过2。 也有很多非坚持连接,您可能希望增加这个值。默认值是1。compressableMimeType:配置想压缩的数据类型URIEncoding:网站一样平常采取UTF-8作为默认编码。processorCache:协议处理器缓存的处理器工具来提高性能。 该设置决定多少这些工具的缓存。-1意味着无限的,默认是200。 如果不该用Servlet 3.0异步处理,默认是利用一样的maxThreads设置。 如果利用Servlet 3.0异步处理,默认是利用大maxThreads和预期的并发要求的最大数量(同步和异步)。tcpNoDelay:如果设置为true,TCP_NO_DELAY选项将被设置在做事器套接字,而在大多数情形下提高性能。这是默认设置为true。connectionLinger:秒数在这个连接器将持续利用的套接字时关闭。默认值是 -1,禁用socket 延迟韶光。server:隐蔽Tomcat版本信息,首先隐蔽HTTP头中的版本信息
Executor节点:
官方文档:https://tomcat.apache.org/tomcat-8.5-doc/config/executor.html
五、AJP协议
Tomcat最紧张的功能是供应Servlet/JSP容器,只管它也可以作为独立的Java Web做事器,但它对静态资源(如HTML文件或图像文件)的处理速率,以及供应的Web做事器管理功能方面都不如其他专业的HTTP做事器,如IIS和Apache做事器。因此在实际运用中,常常把Tomcat与其他HTTP做事器集成。对付不支持Servlet/JSP的HTTP做事器,可以通过Tomcat做事器来运行Servlet/JSP组件。
Tomcat做事器通过Connector连接器组件与客户程序建立连接,Connector组件卖力吸收客户的要求,以及把Tomcat做事器的相应结果发送给客户。默认情形下,Tomcat在server.xml中配置了两种连接器:
第一个连接器监听8080端口,卖力建立HTTP连接。在通过浏览器访问Tomcat做事器的Web运用时,利用的便是这个连接器。第二个连接器监听8009端口,卖力和其他的HTTP做事器建立连接。在把Tomcat与其他HTTP做事器集成时,就须要用到这个连接器。
在实际运用中,如果网站的访问量非常大,为了提高访问速率,可以将多个Tomcat做事器与Apache集成,让它们共同分担运行Servlet/JSP组件的任务。JK插件的loadbalancer(负载平衡器)卖力根据在workers.properties文件中预先配置的lbfactor(负载平衡因数)为这些Tomcat做事器分配事情负荷,实现负载平衡。那么,Apache和Tomcat结合的时候,会有如下征象:
Apache会拦截所有要求,将servlet和JSP(.jsp结尾)要求通过AJP交给Tomcat处理,然后再把结果拿到Apache然后返回;Apache将静态资源的访问,(类似html/css/jpg等类型的文件)自己直接处理不交给Tomcat,直接返回;Apache和Tomcat结合之后,Tomcat的HTTP Connector永久不会被用到了,而是用AJP Connector;