亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁技術(shù)文章
文章詳情頁

詳解SpringBoot中的tomcat優(yōu)化和修改

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

項(xiàng)目背景

在做項(xiàng)目的時(shí)候,把SpringBoot的項(xiàng)目打包成安裝包了,在客戶上面安裝運(yùn)行,一切都是那么的完美,可是發(fā)生了意外,對(duì)方突然說導(dǎo)出導(dǎo)入的文件都不行了。我急急忙忙的查看日志,發(fā)現(xiàn)報(bào)了一個(gè)錯(cuò)誤

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)

經(jīng)過分析發(fā)現(xiàn),這是tomcat在啟動(dòng)的時(shí)候會(huì)生成一個(gè)臨時(shí)的上傳文件保存的位置,但是這個(gè)位子默認(rèn)是放在系統(tǒng)的臨時(shí)文件夾中。當(dāng)這個(gè)tomcat創(chuàng)建的文件夾被系統(tǒng)刪除后,這時(shí)在上傳文件就出現(xiàn)問題了。可能對(duì)方服務(wù)器裝上了360管家,會(huì)自動(dòng)刪掉好似

開工

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

server.tomcat.basedir=自定義目錄

3.啟動(dòng)jar包的時(shí)候加上參數(shù) -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 { /** * 文件上傳臨時(shí)路徑 */ @Bean MultipartConfigElement multipartConfigElement() { MultipartConfigFactory factory = new MultipartConfigFactory(); factory.setLocation('自定義目錄'); return factory.createMultipartConfig(); }}

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

接著說優(yōu)化,至于優(yōu)化,我在解決上面的問題發(fā)現(xiàn),tomcat中有一個(gè)配置

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

默認(rèn)值是10, 每隔10s發(fā)生一次young gc,并且CPU使用率長期大于10%。

ContainerBackgroundProcessor這個(gè)線程是干什么的?

Tomcat的Engine會(huì)啟動(dòng)一個(gè)線程(就是ContainerBackgroundProcessor),該線程每10s會(huì)發(fā)送一個(gè)發(fā)送一個(gè)事件,監(jiān)聽到該事件的部署配置類會(huì)自動(dòng)去掃描webapp文件夾下的war包,將其加載成一個(gè)Context,即啟動(dòng)一個(gè)web服務(wù)。同時(shí),該線程還會(huì)調(diào)用子容器Engine、Host、Context、Wrapper各容器組件及與它們相關(guān)的其它組件的backgroundProcess方法。

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

backgroundProcess對(duì)spring mvc的影響主要影響session的過期清理,如果設(shè)置為900,就只會(huì)每隔900s清除過期的session會(huì)話。server.tomcat.background-processor-delay = 900s #調(diào)用backgroundProcess方法之間的延遲。如果未指定持續(xù)時(shí)間后綴,則將使用秒。

到此這篇關(guān)于詳解SpringBoot中的tomcat優(yōu)化和修改的文章就介紹到這了,更多相關(guān)SpringBoot tomcat優(yōu)化和修改內(nèi)容請(qǐng)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標(biāo)簽: Spring
相關(guān)文章:
主站蜘蛛池模板: 精品一区二区三区视频在线观看 | 91视频久久 | 日本限制级在线 | 国产精品久久久久久免费 | 国产欧美精品系列在线播放 | 国产换爱交换乱理伦片 | 尤物视频网站在线观看 | 国产20岁美女一级毛片 | 入逼视频 | 爱爱欧美视频 | 91青草久久久久久清纯 | a黄毛片| 欧美中文字幕一区二区三区 | 免费日本毛片 | 欧美另类偷自拍视频二区 | 日韩在线不卡一区在线观看 | 久久精品一区二区 | 国产在线欧美日韩一区二区 | 日本一级毛片毛片一级毛片 | 亚洲不卡视频在线 | 国产综合自拍 | 久久精品中文字幕一区 | 日韩免费观看 | 日本高清不卡免费 | 免费看黄在线网站 | 亚洲精品手机在线 | 成人免费淫片在线费观看 | 国产露出调教91 | 国产一级在线现免费观看 | 国产自自拍| 成人污| 日韩videossex另类 | 亚洲欧美v视色一区二区 | 美女黄网页 | 国产午夜一级鲁丝片 | 久久久99精品久久久 | 亚洲视频免费在线播放 | 国外成人免费高清激情视频 | 国产亚洲美女精品久久久久狼 | 国产亚洲欧美日韩在线一区 | 国产精品欧美在线不卡 |