SpringBoot項目配置Tomcat和JVM參數


設置Tomcat端口號和連接數等

使用application.properties配置文件有一些參數無法設置,所以推薦創建一個類文件來配置,如下:

復制代碼
 1 package com.qipai.springbean;
 2 
 3 import org.apache.catalina.connector.Connector;
 4 import org.apache.coyote.http11.Http11NioProtocol;
 5 import org.springframework.boot.context.embedded.EmbeddedServletContainer;
 6 import org.springframework.boot.context.embedded.tomcat.TomcatEmbeddedServletContainerFactory;
 7 import org.springframework.boot.web.servlet.ServletContextInitializer;
 8 import org.springframework.stereotype.Component;
 9 
13 @Component
14 public class TomcatConfig extends TomcatEmbeddedServletContainerFactory
15 {
16     public EmbeddedServletContainer getEmbeddedServletContainer(ServletContextInitializer... initializers)
17     {
18         //設置端口
19         this.setPort(8081);
20         return super.getEmbeddedServletContainer(initializers);
21     }
22 
23     protected void customizeConnector(Connector connector)
24     {
25         super.customizeConnector(connector);
26         Http11NioProtocol protocol = (Http11NioProtocol)connector.getProtocolHandler();
27         //設置最大連接數
28         protocol.setMaxConnections(200);
29         //設置最大線程數
30         protocol.setMaxThreads(300);
31         //連接超時時間
32         protocol.setConnectionTimeout(10000);
33     }
34 }
復制代碼

也可以使用application.properties配置文件來配置,如下,但是沒有連接超時時間的配置。

復制代碼
#端口號
server.port=8081
#最大連接數
server.tomcat.max-connections=200
#最大線程數
server.tomcat.max-threads=300
#編碼方式
server.tomcat.uri-encoding=UTF-8
#post提交數據最大大小,設置為0不限制
server.tomcat.max-http-post-size=0
復制代碼

運行時設置JVM參數

先使用Maven打包成jar文件

cd /項目路徑

mvn clean package

使用默認JVM配置運行

復制代碼
#前台運行,關閉窗口后退出
java -jar /jar包路徑

#后台運行
nohup java -jar /jar包路徑

#后台運行,指定啟動日志記錄文件
nohub java -jar /jar包路徑 > /指定日志文件路徑
復制代碼

配置JVM參數運行

#前台運行
java -XX:MetaspaceSize=128m -XX:MaxMetaspaceSize=128m -Xms1024m -Xmx1024m -Xmn256m -Xss256k -XX:SurvivorRatio=8 -XX:+UseConcMarkSweepGC -jar /jar包路徑 

nohup java -XX:MetaspaceSize=128m -XX:MaxMetaspaceSize=128m -Xms1024m -Xmx1024m -Xmn256m -Xss256k -XX:SurvivorRatio=8 -XX:+UseConcMarkSweepGC -jar /jar包路徑 

參數說明:

-XX:MetaspaceSize=128m (元空間默認大小)

-XX:MaxMetaspaceSize=128m (元空間最大大小)

-Xms1024m (堆最大大小)

-Xmx1024m (堆默認大小)

-Xmn256m (新生代大小)

-Xss256k (棧最大深度大小)

-XX:SurvivorRatio=8 (新生代分區比例 8:2)

-XX:+UseConcMarkSweepGC (指定使用的垃圾收集器,這里使用CMS收集器)

 

知識點:JDK8之后把-XX:PermSize 和 -XX:MaxPermGen移除了,取而代之的是

-XX:MetaspaceSize=128m (元空間默認大小)

-XX:MaxMetaspaceSize=128m (元空間最大大小)

JDK 8開始把類的元數據放到本地化的堆內存(native heap)中,這一塊區域就叫Metaspace,中文名叫元空間。

使用本地化的內存有什么好處呢?最直接的表現就是java.lang.OutOfMemoryError: PermGen 空間問題將不復存在,因為默認的類的元數據分配只受本地內存大小的限制,也就是說本地內存剩余多少,理論上Metaspace就可以有多大(貌似容量還與操作系統的虛擬內存有關?這里不太清楚),這解決了空間不足的問題。不過,讓Metaspace變得無限大顯然是不現實的,因此我們也要限制Metaspace的大小:使用-XX:MaxMetaspaceSize參數來指定Metaspace區域的大小。JVM默認在運行時根據需要動態地設置MaxMetaspaceSize的大小。

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM