tomcat正常运行一段时间后,忽然访问不了项目了

前言

我将项目部署在tomcat服务器上,原本都是好好的,输入网站地址就能访问;可是次日一早去就会发现网站访问提示404,文件没法找到;我就很懵了。java

排查

  • 一、我是用的是chrome浏览器,因此尝试了下其他浏览器看是否可以访问;之外的发现IE居然能够访问。说明问题不在代码
  • 二、找到tomcat的安装目录,查看错误日志;在logs文件夹下便可找到相似 catalina.2019-09-22.log 的文件

    打开文件夹后就看到了报错信息:
  • 三、而后靠万能的百度就分分钟解决了

报错信息:

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)chrome

解决方法:

在Tomcat的server.xml中找到apache

<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

忽然发现本身的服务器是开了两个tomcat,虽然端口号各不相同,但有没多是这个形成的缘由呢?服务器

而后我关闭其中一个,如今过去大半个月了,依旧正常运行。app

相关文章
相关标签/搜索