我们在使用springboot开发web项目时,大多数时候采用的是内置的Tomcat(当然也可以配置支持内置的jetty),内置Tomcat有什么好处呢?
1、方便微服务部署,减少繁杂的配置
2、方便项目启动,不需要单独下载web容器,如Tomcat,jetty等。
针对目前的容器优化,可以从以下几点考虑:
1、线程数
2、超时时间
3、JVM优化
首先,线程数是一个重点,比较重要的有两个:初始线程数和最大线程数。
初始线程数:保障启动的时候,如果有大量用户访问,能够很稳定的接受请求。最大线程数:用来保证系统的稳定性。
超时时间:用来保障连接数不容易被压垮。如果大批量的请求过来,延迟比较高,很容易把线程数用光,这时就需要提高超时时间。这种情况在生产中是比较常见的 ,一旦网络不稳定,宁愿丢包也不能把服务器压垮。
min-spare-threads
最小备用线程数,tomcat启动时的初始化的线程数。
max-threads
Tomcat可创建的最大的线程数,每一个线程处理一个请求,超过这个请求数后,客户端请求只能排队,等有线程释放才能处理。
connection-timeout
最长等待时间,如果没有数据进来,等待一段时间后断开连接,释放线程。
在spring boot配置文件中application.yml,添加以下配置:
这块对tomcat进行了一个优化配置,最大线程数是1000,初始化线程是30,超时时间是5000ms
JVM优化
JVM优化一般来说没有太多场景,无非就是加大初始的堆,和最大限制堆,当然也不能无限增大,要根据实际情况优化。
初始内存和最大内存基本会设置成一样的,具体大小根据场景设置,-server是一个必须要用的参数,至于收集器这些使用默认的就可以了,除非有特定需求。
1.使用-server模式
设置JVM使用server模式。64位JDK默认启动该模式。
2.指定堆参数
这个根据服务器的内存大小,来设置堆参数。
-Xms :设置Java堆栈的初始化大小
-Xmx :设置最大的java堆大小
设置初始化堆内存为512MB,最大为768MB。
领取专属 10元无门槛券
私享最新 技术干货