Springboot配置Tomcat运行参数,优化JVM提高系统稳定性

我们在使用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。

  • 发表于:
  • 原文链接https://kuaibao.qq.com/s/20190821A0I4K400?refer=cp_1026
  • 腾讯「云+社区」是腾讯内容开放平台帐号(企鹅号)传播渠道之一,根据《腾讯内容开放平台服务协议》转载发布内容。

扫码关注云+社区

领取腾讯云代金券