apache 优化配置java_ApacheTomcat 8 9 安全配置与高并发优化

编辑修改配置文件

[root@DaMoWang ~]# vim /usr/local/tomcat/conf/server.xml

禁用8005端口

telnet localhost 8005 然后输入 SHUTDOWN 就可以关闭 Tomcat,为了安全我们要禁用该功能

# 修改为

应用程序安全&关闭自动部署

unpackWARs="true" autoDeploy="true">

# 修改为

unpackWARs="false" autoDeploy="false" reloadable="false">

maxThreads 连接数限制修改配置

69c5a8ac3fa60e0848d784a6dd461da6.png

# 修改为

name="tomcatThreadPool"

namePrefix="catalina-exec-"

maxThreads="500"

minSpareThreads="30"

maxIdleTime="60000"

prestartminSpareThreads = "true"

maxQueueSize = "100"

/>

69c5a8ac3fa60e0848d784a6dd461da6.png

参数解释:

maxThreads:最大并发数,默认设置 200,一般建议在 500 ~ 800,根据硬件设施和业务来判断

minSpareThreads:Tomcat 初始化时创建的线程数,默认设置 25

maxIdleTime:如果当前线程大于初始化线程,那空闲线程存活的时间,单位毫秒,默认60000=60秒=1分钟。

prestartminSpareThreads:在 Tomcat 初始化的时候就初始化 minSpareThreads 的参数值,如果不等于 true,minSpareThreads 的值就没啥效果了

maxQueueSize:最大的等待队列数,超过则拒绝请求

Connector 参数优化配置

69c5a8ac3fa60e0848d784a6dd461da6.png

port="8080"

protocol="HTTP/1.1"

connectionTimeout="20000"

redirectPort="8443"

/>

# 修改为

executor="tomcatThreadPool"

port="8080"

protocol="org.apache.coyote.http11.Http11Nio2Protocol"

connectionTimeout="60000"

maxConnections="10000"

redirectPort="8443"

enableLookups="false"

acceptCount="100"

maxPostSize="10485760"

maxHttpHeaderSize="8192"

compression="on"

disableUploadTimeout="true"

compressionMinSize="2048"

acceptorThreadCount="2"

compressableMimeType="text/html,text/plain,text/css,application/javascript,application/json,application/x-font-ttf,application/x-font-otf,image/svg+xml,image/jpeg,image/png,image/gif,audio/mpeg,video/mp4"

URIEncoding="utf-8"

processorCache="20000"

tcpNoDelay="true"

connectionLinger="5"

server="Server Version 11.0"

/>

69c5a8ac3fa60e0848d784a6dd461da6.png

参数解释:

protocol:Tomcat 7 设置 nio2 更好:org.apache.coyote.http11.Http11Nio2Protocol

protocol:Tomcat 6 设置 nio 更好:org.apache.coyote.http11.Http11NioProtocol

protocol:Tomcat 8 设置 APR 性能飞快:org.apache.coyote.http11.Http11AprProtocol  具体配置 :

connectionTimeout: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头中的版本信息

隐藏或修改 Tomcat 版本号

69c5a8ac3fa60e0848d784a6dd461da6.png

[root@DaMoWang conf]# cd /usr/local/tomcat/lib/

[root@DaMoWang lib]# unzip catalina.jar

[root@DaMoWang lib]# cd org/apache/catalina/util/

[root@DaMoWang util]# vim ServerInfo.properties

server.info=Apache Tomcat/9.0.10

server.number=9.0.10.0

server.built=Jun 20 2018 17:32:21 UTC

# 对以上内容修改或删除版本号即可

69c5a8ac3fa60e0848d784a6dd461da6.png

删除禁用默认管理页面以及相关配置文件

[root@DaMoWang util]# rm -rf /usr/local/tomcat/conf/tomcat-users.xml

[root@DaMoWang util]# rm -rf /usr/local/tomcat/webapps/*

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值