設置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的大小。