亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

SpringBoot中的tomcat如何修改和優化

發布時間:2020-10-29 19:49:50 來源:億速云 閱讀:301 作者:Leah 欄目:開發技術

SpringBoot中的tomcat如何修改和優化?很多新手對此不是很清楚,為了幫助大家解決這個難題,下面小編將為大家詳細講解,有這方面需求的人可以來學習下,希望你能有所收獲。

項目背景

在做項目的時候,把SpringBoot的項目打包成安裝包了,在客戶上面安裝運行,一切都是那么的完美,可是發生了意外,對方突然說導出導入的文件都不行了。我急急忙忙的查看日志,發現報了一個錯誤

java.io.IOException: The temporary upload location [C:\Windows\Temp\tomcat.1351070438015228346.8884\work\Tomcat\localhost\ROOT] is not valid
 at org.apache.catalina.connector.Request.parseParts(Request.java:2821)
 at org.apache.catalina.connector.Request.parseParameters(Request.java:3185)
 at org.apache.catalina.connector.Request.getParameter(Request.java:1116)
 at org.apache.catalina.connector.RequestFacade.getParameter(RequestFacade.java:381)
 at org.springframework.web.filter.HiddenHttpMethodFilter.doFilterInternal(HiddenHttpMethodFilter.java:84)
 at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107)
 at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193)
 at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)
 at org.springframework.web.filter.CharacterEncodingFilter.doFilterInternal(CharacterEncodingFilter.java:200)
 at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107)
 at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193)
 at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)
 at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:199)
 at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:96)
 at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:490)
 at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:139)
 at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:92)
 at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:74)
 at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:343)
 at org.apache.coyote.http11.Http11Processor.service(Http11Processor.java:408)
 at org.apache.coyote.AbstractProcessorLight.process(AbstractProcessorLight.java:66)
 at org.apache.coyote.AbstractProtocol$ConnectionHandler.process(AbstractProtocol.java:791)
 at org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1417)
 at org.apache.tomcat.util.net.SocketProcessorBase.run(SocketProcessorBase.java:49)
 at java.util.concurrent.ThreadPoolExecutor.runWorker(Unknown Source)
 at java.util.concurrent.ThreadPoolExecutor$Worker.run(Unknown Source)
 at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61)
 at java.lang.Thread.run(Unknown Source)

經過分析發現,這是tomcat在啟動的時候會生成一個臨時的上傳文件保存的位置,但是這個位子默認是放在系統的臨時文件夾中。當這個tomcat創建的文件夾被系統刪除后,這時在上傳文件就出現問題了。可能對方服務器裝上了360管家,會自動刪掉好似

開工

針對這一個異常有以下解決方法
1.萬能的重啟,絕大多數的問題解決方法,“你重啟一下試試”。但是這個方法只能解決得了一時,解決不了一世啊。
2.在配置文件中加上

server.tomcat.basedir=自定義目錄

3.啟動jar包的時候加上參數 -Djava.io.tmpdir=自定義目錄

java -jar xx.jar -Djava.io.tmpdir=自定義目錄 

4.添加配置bean

import org.springframework.boot.web.servlet.MultipartConfigFactory;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;


import javax.servlet.MultipartConfigElement;

@Configuration
public class TomcatBeanConfig {

  /**
   * 文件上傳臨時路徑
   */
  @Bean
  MultipartConfigElement multipartConfigElement() {
    MultipartConfigFactory factory = new MultipartConfigFactory();
    factory.setLocation("自定義目錄");
    return factory.createMultipartConfig();
  }
}

-------------------------------------分隔符 ------------------------------------------

接著說優化,至于優化,我在解決上面的問題發現,tomcat中有一個配置

# 后臺線程方法的delay大小每隔900s清除過期的session會話
server.tomcat.background-processor-delay=900

默認值是10, 每隔10s發生一次young gc,并且CPU使用率長期大于10%。

ContainerBackgroundProcessor這個線程是干什么的?

Tomcat的Engine會啟動一個線程(就是ContainerBackgroundProcessor),該線程每10s會發送一個發送一個事件,監聽到該事件的部署配置類會自動去掃描webapp文件夾下的war包,將其加載成一個Context,即啟動一個web服務。同時,該線程還會調用子容器Engine、Host、Context、Wrapper各容器組件及與它們相關的其它組件的backgroundProcess方法。

個人理解是,每隔10S對session的過期清理過于頻繁從而導致CPU占用率過高,
我改成了900,就是每900秒檢測一次,這樣就降低CPU占用率啦

backgroundProcess對spring mvc的影響
主要影響session的過期清理,如果設置為900,
就只會每隔900s清除過期的session會話。

server.tomcat.background-processor-delay = 900s 
#調用backgroundProcess方法之間的延遲。如果未指定持續時間后綴,則將使用秒。

看完上述內容是否對您有幫助呢?如果還想對相關知識有進一步的了解或閱讀更多相關文章,請關注億速云行業資訊頻道,感謝您對億速云的支持。

向AI問一下細節
推薦閱讀:
  1. Tomcat 優化
  2. tomcat 優化

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

新河县| 长岭县| 文水县| 威远县| 新丰县| 阜宁县| 汉沽区| 潼南县| 漳浦县| 柞水县| 蒙城县| 花莲县| 荆州市| 营山县| 桦甸市| 嘉祥县| 新源县| 临清市| 万荣县| 齐河县| 富民县| 天津市| 宿松县| 嘉兴市| 新丰县| 德安县| 温州市| 禹州市| 犍为县| 阳西县| 平湖市| 阿拉善左旗| 桂平市| 离岛区| 黄龙县| 甘孜县| 如东县| 镇远县| 会昌县| 富宁县| 青浦区|