JVM 和 Tomcat的关系
1.什么是jvm
我们从操作系统的层面来理解,jvm其实就是操作系统中的一个进程。既然是一个进程,那么我们很容易的可以通过任务管理器来查看。假设此时我们启动myeclipse(myeclipse其实就是用java语言编写的一个软件,他的运行必然会启动一个jvm,我们可以把myeclipse理解成我们自己写的一个简单的java版的helloworld程序)。查看任务管理器的截图如下:
2.什么是tomcat
tomcat其实是一个用java语言开发的免费开源的web服务器(因为是java语言开发,这就是为什么使用tomcat前要配置好jdk,因为jdk里面有jvm,而运行java应用需要jvm)。此时再次查看任务管理器会发现多了一个javaw.exe
同一个tomcat下的java ee项目使用的是不是同一个jvm?答案是是的。(使用的都是启动tomcat的jvm)这个可以通过启动不同的web应用来自己判断。
如果运行的是普通的java se程序,使用的是不是同一个jvm呢?答案是否。这个可以自己运行程序判断。(可以写一个很简单的while死循环,便于查看)。
一、查看Tomcat的JVM的内存情况
1、通过浏览器:Tomcat的Admin登录之后可以查看Tomcat内存情况和部署情况
访问:http://localhost:8080/manager/status 然后输入用户名密码登录既可以看到tomcat内存情况和部署情况
但是用户名密码是多少呢 ? 需要在配置文件下开启
<role rolename="admin"/>
<role rolename="manager"/>
<user username="admin" password="admin" roles="admin,manager"/>
<role rolename="admin-gui"/>
<role rolename="manager-gui"/>
<user username="admin" password="admin" roles="admin-gui,manager-gui"/>
2、通过命令的方式查看Tomcat的JVM内存
1、ps -ef | grep tomcat_sdnews 查出tomcat的进程号
2、jmap -heap tomcat进程号 查看tomcat内存分配比例
二、Tomcat由猫变虎(Tomcat的优化)
1、Tomcat启动优化(JVM内存优化)------ %TOMCAT_HOME%/bin/catalina.sh文件(大概97行)
修改内容如下:
export JAVA_OPTS="-server -Xms1600M -Xmx1600M -Xss512k -XX:+AggressiveOpts -XX:+UseBiasedLocking -XX:PermSize=128M -XX:MaxPermSize=256M -XX:+DisableExplicitGC -XX:MaxTenuringThreshold=31 -XX:+UseConcMarkSweepGC -XX:+UseParNewGC -XX:+CMSParallelRemarkEnabled -XX:+UseCMSCompactAtFullCollection -XX:LargePageSizeInBytes=128m -XX:+UseFastAccessorMethods -XX:+UseCMSInitiatingOccupancyOnly -Djava.awt.headless=true"
参数说明:https://blog.csdn.net/wxd_1024/article/details/80653211
2、Tomcat并发优化 ------ %TOMCAT_HOME%/conf/server.xml文件 <Connector>节点的配置优化
tomcat默认配置为:
tomcat优化后
标准版
<Connector port="8080" protocol="org.apache.coyote.http11.Http11NioProtocol"
//将默认出场的BIO模式更换为NIO 最好的是APR
maxThreads="600" //最大线程数
minSpareThreads="100"
maxSpareThreads="500"
acceptCount="700"
connectionTimeout="20000"
redirectPort="8443" />
复杂版
<Connector port="8080" protocol="org.apache.coyote.http11.Http11NioProtocol"
URIEncoding="UTF-8" //使得tomcat可以解析含有中文名的文件的url
minSpareThreads="25"
maxSpareThreads="75" //最小备用线程数,tomcat启动时的初始化的线程数,默认10.
enableLookups="false"
disableUploadTimeout="true"
acceptCount="300"
//acceptCount是当线程数达到maxThreads后,后续请求会被放入一个等待队列,这个acceptCount是这个队列的大小,如果这个队列也满了,就直接refuse connection。一句话:acceptCount:当处理任务的线程数达到最大时,接受排队的请求个数,默认100
maxThreads="300"
//maxThreads:最大线程数,即同时处理的任务个数,默认值为200 推荐 600-900
maxProcessors="1000"
minProcessors="5"
useURIValidationHack="false"
compression="on"
compressionMinSize="2048"
compressableMimeType="text/html,text/xml,text/JavaScript,text/css,text/plain"
connectionTimeout="20000"
redirectPort="8443"/>
参数说明:https://blog.csdn.net/wxd_1024/article/details/80654136
最后不要忘了把8443端口的地方也加上同样的配置,因为如果我们走https协议的话,我们将会用到8443端口这段的配置