国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術文章
文章詳情頁

詳解SpringBoot中的tomcat優化和修改

瀏覽:4日期:2023-04-19 13:07:52

項目背景

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

java.io.IOException: The temporary upload location [C:WindowsTemptomcat.1351070438015228346.8884workTomcatlocalhostROOT] 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;@Configurationpublic 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方法之間的延遲。如果未指定持續時間后綴,則將使用秒。

到此這篇關于詳解SpringBoot中的tomcat優化和修改的文章就介紹到這了,更多相關SpringBoot tomcat優化和修改內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Spring
相關文章:
主站蜘蛛池模板: 欧美成人ass | 国产成人a一在线观看 | 久久精品免费播放 | 日本一本久 | 97在线观看完整免费 | 国产日产欧美精品一区二区三区 | 欧美在线播放成人免费 | 久草在线观看福利 | 久久久久久久国产精品视频 | 美女被cao免费看在线看网站 | 亚洲久久网站 | 欧美专区在线视频 | 午夜性生活视频 | 国产精品亚洲一区二区三区在线观看 | 91aaa免费免费国产在线观看 | 66精品 | a级高清 | 怡红院免费播放全部视频 | 亚洲图片一区二区三区 | 在线视频第一页 | 日韩成人免费在线 | 中国美女一级黄色片 | 欧美日韩一区二区三区在线 | 999久久久 | 欧美一区二区三区免费不卡 | 成人欧美在线 | 国产不卡精品一区二区三区 | 欧美a欧美1级 | 亚洲欧美日韩精品久久久 | 亚洲欧美视频一区二区三区 | 国产在线拍揄自揄视精品不卡 | 131的美女午夜爱爱爽爽视频 | 亚洲天天| 韩国免费特一级毛片 | 久久久久成人精品一区二区 | 好湿好紧好痛a级是免费视频 | 欧美在线成人午夜网站 | www日本免费 | 成人 在线播放 | 欧美视频在线一区二区三区 | 国产精品天堂avav在线 |