spring boot使用内嵌tomcat,怎么配置内置tomcat的内存?
spring boot使用内嵌tomcat,怎么配置内置tomcat的内存?使用外部,只要在catalina.sh配置下就行了,那内置的怎么操作呢?
答案:
springboot只是内嵌了tomcat而已, 所以使用的内存其实就是springboot这个进程的内存,所以可以通过启动命令的时候 增加 -Xmx -Xms 这类的参数来设置内存的大小。
tomcat是没有单独配置内存大小一说的, 你说的之前的catalina.sh里面设置的内存大小其实也只是针对这个启动进程进行配置。
另外一些tomcat的配置可以在server.tomcat下面进行配置,主要是配置tomcat容器的最大连接数这类的参数。
具体操作为:
要加“m”说明是MB,否则就是KB了.
-Xms:初始值
-Xmx:最大值
-Xmn:最小值
java -Xms10m -Xmx80m -jar mod.jar & 时区设置 java -jar -Duser.timezone=GMT+08
mod.jar &
使用配置文件:
与Spring Boot项目同路径下新建一同名配置文件
项目为boot.jar,新建文件boot.conf,项目启动之后默认读取该配置文件
1、jvm运行参数
JAVA_OPTS="-Xms2048m -Xmx2048m -Xss512k"
-Xms:初始Heap大小,使用的最小内存,cpu性能高时此值应设的大一些
-Xmx:Java heap最大值,使用的最大内存
上面两个值是分配JVM的最小和最大内存,取决于硬件物理内存的大小,建议均设为物理内存的一半。
-XX:PermSize:设定内存的永久保存区域
-XX:MaxPermSize:设定最大内存的永久保存区域
-XX:MaxNewSize:
-Xss 15120 这使得JBoss每增加一个线程(thread)就会立即消耗15M内存,而最佳值应该是128K,默认值好像是512k.
+XX:AggressiveHeap 会使得 Xms没有意义。这个参数让jvm忽略Xmx参数,疯狂地吃完一个G物理内存,再吃尽一个G的swap。
-Xss:每个线程的Stack大小
-verbose:gc 现实垃圾收集信息
-Xloggc:gc.log 指定垃圾收集日志文件
-Xmn:young generation的heap大小,一般设置为Xmx的3、4分之一
-XX:+UseParNewGC :缩短minor收集的时间
-XX:+UseConcMarkSweepGC :缩短major收集的时间
提示:此选项在Heap Size 比较大而且Major收集时间较长的情况下使用更合适。
2、项目运行参数
RUN_ARGS="--server.port=8081 --logging.level=INFO --spring.thymeleaf.cache=true --logging.file=/var/log/demo.lo
业务需求变更永无休止,技术前进就永无止境!