Tomcat涉及的配置文件主要有三种,web项目中自带的WEB-INF/web.xml,tomcat自带的conf/web.xml以及conf/server.xml文件。
长话短说,我们以结果和需求为导向,根据需要达成的效果来分析和修改对应的配置文件和代码段。
以tomcat8为例,默认线程连接使用的是NIO或NIO2(非阻塞I/O模型)。
一、并发优化
编辑 server.xml 的 Connector 元素
maxThreads="600"
minSpareThreads="100"
maxSpareThreads="500"
acceptCount="700"
connectionTimeout="20000" />
解读:
连接器使用端口 8080,使用协议 http1.1
最大线程数,600,Tomcat可创建的最大的线程数,每一个线程处理一个请求
最小备用线程数,100,tomcat启动时的初始化的线程数
最大备用线程数,500,创建的线程超过这个值,Tomcat就会关闭不再需要的socket线程
排队数,表示当现有请求数达到maxThreads,可以安排700个请求排队,其它请求将被拒绝
二、内存优化
Java的逻辑内存模型大致分为堆内存、栈内存、静态内存区
(1)堆内存
用于存储new生成的对象,JVM默认堆的最小使用内存为物理内存的1/64,最大使用内存为物理内存的1/4,如8G物理内存,最小最大分别支持128M和2G
java.lang.OutOfMemoryError: Java heap space异常
表示堆内存空间满了,可能是因为项目中引用的jar比较多,导到内存溢出
(2)栈内存
用于存储局部变量
java.lang.StackOverflowError异常
表示栈内存溢出。通常是由于死循环、无限递归导致。
(3)静态内存
存储常量、静态变量、类元数据信息(方法、属性等)
java.lang.OutOfMemoryError: PermGen space异常
静态内存区满了,通常是由于加载的类过多导致,JDK8改变了内存逻辑模型,不再有此问题
编辑 bin/catalina.sh文件,在JAVA_OPTS参数上添加内存参数
以一台8G专门跑tomcat的linux服务器为例:JAVA_OPTS="$JAVA_OPTS
-server
以server方式启动(默认是client),较大提升性能-Xms4096m
-Xmx4096m
JVM初始内存,4096M
JVM最大内存,4096M
建议二者配置同一值,即物理内存的1/2-XX:PermSize=256m
-XX:MaxPermSize=512m
非堆内存初始值,256M,建议改为物理内存1/32
非堆内存最大值,512M,建议为PermSize的2倍
(Xmx + XX:MaxPermSize 的值,不能超出操作系统的可用内存。)-Djava.awt.headless=true"
解决图片在 Linux 上无法显示图片的问题,适用于无图形化界面的服务器。
三、设置虚拟主机(监听主机名)
编辑 server.xml 的 Host 元素,通过定义不同的Hostname和appBase实现
name="http://www.zhihu.com"
appBase="webapps"
unpackWARs="true"
autoDeploy="false">
项目目录 webapps
unpackWARs="true",自动将WAR包解压,否则不解压,直接从WAR文件中运行应用程序
autoDeploy="false",取消热部署,节省服务器资源
元素内编辑日志信息
通过定义不同的Hostname和appBase实现
四、设置虚拟主机(监听端口)
编辑 server.xml 文件,创建不同的 Service 元素
分别修改其下的:
Connector 元素,修改监听端口
Engine 元素,修改启动脚本
Host 元素,修改主机名和项目目录(同第三部分)
以下是一个完整的修改范例:
prefix="localhost_access_log." suffix=".txt"
pattern="%h %l %u %t "%r" %s %b" />
bin/catalina.sh start
五,动静分离
使用nginx的proxy_pass和upstream实现,将jsp类型的访问转发给后端tomcat服务器
nginx处理静态请求,tomcat处理动态请求,这是一种业内常用的动静分离方案
致谢:
本文内容细节来源于网络,经个人整理,感谢所有乐于分享技术经验的工程师们