tomcat正常運行一段時間后,突然訪問不了項目了


前言

我將項目部署在tomcat服務器上,本來都是好好的,輸入網站地址就能訪問;但是第二天一早去就會發現網站訪問提示404,文件無法找到;我就很懵了。

排查

  • 1、我是用的是chrome瀏覽器,所以嘗試了下其余瀏覽器看是否能夠訪問;以外的發現IE竟然可以訪問。說明問題不在代碼
  • 2、找到tomcat的安裝目錄,查看錯誤日志;在logs文件夾下即可找到類似 catalina.2019-09-22.log 的文件

    打開文件夾后就看到了報錯信息:
  • 3、然后靠萬能的百度就分分鍾解決了

報錯信息:

22-Sep-2019 18:15:22.184 INFO [http-nio-8080-exec-7] org.apache.coyote.http11.Http11Processor.service Error parsing HTTP request header
Note: further occurrences of HTTP header parsing errors will be logged at DEBUG level.
java.lang.IllegalArgumentException: Invalid character found in method name. HTTP method names must be tokens
at org.apache.coyote.http11.Http11InputBuffer.parseRequestLine(Http11InputBuffer.java:426)
at org.apache.coyote.http11.Http11Processor.service(Http11Processor.java:687)
at org.apache.coyote.AbstractProcessorLight.process(AbstractProcessorLight.java:66)
at org.apache.coyote.AbstractProtocol$ConnectionHandler.process(AbstractProtocol.java:790)
at org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1459)
at org.apache.tomcat.util.net.SocketProcessorBase.run(SocketProcessorBase.java:49)
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1149)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:624)
at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61)
at java.lang.Thread.run(Thread.java:748)

解決方法:

在Tomcat的server.xml中找到

<Connector port="8080" protocol="HTTP/1.1" connectionTimeout="20000" redirectPort="8443"/>

這個標簽,添加maxHttpHeaderSize="9999"這一屬性。

    <Connector executor="tomcatThreadPool"
	       maxHttpHeaderSize="9999" 
               port="8080" protocol="HTTP/1.1"
               connectionTimeout="20000"
               redirectPort="8443" />

過了幾天依然出現了這個錯誤。

突然發現自己的服務器是開了兩個tomcat,雖然端口號各不相同,但有沒可能是這個造成的原因呢?

然后我關閉其中一個,現在過去大半個月了,依舊正常運行。

總結

查看logs目錄下的catalina.out日志文件真的很重要,這是可以看到報錯信息的,能讓你快速定位問題!


免責聲明!

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



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