启动tomcat报StandardServer.await: create[8005]

启动tomcat报StandardServer.await: create[8005]

今天发现朋友在启动tomcat时出现以下错误

2012-5-9 8:58:26  org.apache.coyote.http11.Http11AprProtocol start
INFO: Starting Coyote HTTP/1.1 on http-8080
2012-5-9 8:58:26  org.apache.coyote.ajp.AjpAprProtocol start
INFO: Starting Coyote AJP/1.3 on ajp-8009
2012-5-9 8:58:26  org.apache.catalina.startup.Catalina start
INFO: Server startup in 4218 ms
2012-5-9 8:58:26  org.apache.catalina.core.StandardServer await
SEVERE: StandardServer.await: create[8005]:
java.net.BindException: Cannot assign requested address
        at java.net.PlainSocketImpl.socketBind(Native Method)
        at java.net.PlainSocketImpl.bind(PlainSocketImpl.java:365)
        at java.net.ServerSocket.bind(ServerSocket.java:319)
        at java.net.ServerSocket.<init>(ServerSocket.java:185)
        at org.apache.catalina.core.StandardServer.await(StandardServer.java:373)
        at org.apache.catalina.startup.Catalina.await(Catalina.java:647)
        at org.apache.catalina.startup.Catalina.start(Catalina.java:607)
        at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
        at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
        at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
        at java.lang.reflect.Method.invoke(Method.java:597)
        at org.apache.catalina.startup.Bootstrap.start(Bootstrap.java:288)
        at org.apache.catalina.startup.Bootstrap.main(Bootstrap.java:413)

 

开始出现这错误,我的第一反应就是端口被占用,但经过反复查看端口并未被占用,日志中也可以看到 tomcat是已经启动了, 但不能绑定8005端口. 出现Cannot assign requested address,果断搜索了一番,查看很多都是因为端口被占用导致,但也有不是的,其中有一篇是说出现Cannot assign requested address的原因是localhost被路由到了别的机器.

在命令窗口

ping localhost 

发现确实被路由到了别的机器.

 这下就解决问题了,修改localhost让它重新指向本机地址 127.0.0.1vi /etc/hosts删除掉里面关于localhost的转向, 然后增加一行

127.0.0.1 localhost    

重新启动tomcat, 问题都解决.

<think>好的,我现在需要帮助用户解决他们遇到的“StandardServer.await: Invalid command 'GET / HTTP/1.1' received”错误。首先,我得理解这个错误信息的具体含义和可能的原因。 根据用户提供的信息,错误信息提到了StandardServer.await和无效的命令“GET / HTTP/1.1”。这让我想到,StandardServer可能是Tomcat中的一个类,负责处理服务器的等待连接。当接收到无效命令时,可能会抛出这样的错误。 接下来,我需要考虑为什么Tomcat会认为GET请求是无效命令。通常,HTTP请求行应该以方法、URI和协议版本组成,例如“GET / HTTP/1.1”是正确的格式。如果Tomcat认为这是无效的,可能是在解析请求时出现了问题,导致无法识别有效的HTTP方法。 可能的原因有几个: 1. **端口冲突或配置错误**:用户可能错误地将Tomcat的连接器(如AJP或HTTP连接器)配置到了错误的端口,例如数据库端口(如3306),而不是默认的HTTP端口(8080)或AJP端口(8009)。当客户端发送HTTP请求到非HTTP端口时,服务器可能无法正确解析请求,导致将HTTP命令视为无效。 2. **协议不匹配**:例如,如果连接器配置为使用AJP协议,但客户端发送的是HTTP请求,Tomcat无法处理这种情况,从而错。 3. **防火墙或代理问题**:中间的网络设备可能修改了请求,或者在错误的端口上转发了流量,导致Tomcat接收到不符合预期的数据。 4. **客户端错误**:客户端可能发送了格式错误的请求,或者在建立连接后没有正确发送HTTP请求,例如直接使用telnet或netcat发送了不完整的请求。 接下来,我需要验证这些可能性,并给出相应的解决步骤。用户可能需要检查他们的Tomcat配置文件(如server.xml),确认连接器的端口和协议是否正确。特别是检查是否有连接器被配置到了数据库或其他服务的端口上。例如,如果HTTP连接器被错误地设置为3306端口,而MySQL正在使用该端口,当客户端尝试通过该端口发送HTTP请求时,Tomcat会接收到这些请求但无法正确处理,导致错误。 此外,用户可能需要检查网络配置,确保没有端口转发或代理设置错误。还可以建议用户使用工具如curl或浏览器访问正确的端口,以确认问题是否由端口配置错误引起。 最后,可能需要指导用户如何查看Tomcat的日志文件,以获取更多关于错误发生时的上下文信息,帮助进一步诊断问题。</think>### 问题分析:`StandardServer.await: Invalid command 'GET / HTTP/1.1' received` 此错误通常出现在 **Tomcat服务器** 的日志中,表明Tomcat的`StandardServer`组件接收到了不符合预期的数据格式。以下是逐步解析和解决方案: --- ### 一、根本原因 1. **端口配置错误** Tomcat的**管理端口(默认8005)** 或 **其他非HTTP端口**(如AJP端口8009)被误配置为接收HTTP请求。 - 例如:客户端向`8005`端口发送了HTTP请求`GET / HTTP/1.1`,但此端口仅用于`SHUTDOWN`命令,而非处理HTTP流量。 2. **协议不匹配** - 如果Tomcat的`Connector`配置为使用**AJP协议**(如Apache HTTP Server与Tomcat的集成),但客户端发送了HTTP请求。 3. **客户端误操作** - 用户可能通过`telnet`、`curl`或浏览器直接访问了错误的端口。 --- ### 二、验证步骤 1. **检查Tomcat的`server.xml`配置** 打开`conf/server.xml`,确认以下内容: ```xml <!-- HTTP连接器(应接收浏览器请求) --> <Connector port="8080" protocol="HTTP/1.1" ... /> <!-- AJP连接器(供Apache等代理使用) --> <Connector port="8009" protocol="AJP/1.3" ... /> <!-- 管理端口(仅接受SHUTDOWN命令) --> <Server port="8005" shutdown="SHUTDOWN"> ``` - 确保HTTP请求发送到`8080`端口(或自定义的HTTP端口),而非`8005`或`8009`。 2. **检查客户端请求的端口** - 若通过浏览器访问,确认URL为`http://localhost:8080`(而非其他端口)。 3. **排查防火墙或代理干扰** - 检查是否有反向代理(如Nginx)错误地将流量转发到管理端口。 --- ### 三、解决方案 1. **修正客户端请求的端口** - 将HTTP请求发送到Tomcat的HTTP连接器端口(默认`8080`)。 2. **修改Tomcat配置(如需)** - 若需更改管理端口,编辑`server.xml`中的`<Server port="8005">`,例如改为`8006`: ```xml <Server port="8006" shutdown="SHUTDOWN"> ``` 3. **协议一致性检查** - 若使用AJP协议,确保前端代理(如Apache)正确配置AJP转发,而非HTTP转发。 --- ### 四、示例错误场景 ```log // 错误日志示例 org.apache.catalina.core.StandardServer await Invalid command 'GET / HTTP/1.1' received ``` - **原因**:用户在浏览器中访问了`http://localhost:8005`(Tomcat管理端口),但此端口仅支持`SHUTDOWN`命令。 - **解决**:改为访问`http://localhost:8080`。 --- ### 五、高级调试 1. **使用`netstat`检查端口占用** ```bash netstat -tuln | grep '8005\|8080\|8009' ``` - 确认Tomcat端口未被其他进程占用。 2. **抓包分析** ```bash tcpdump -i lo port 8005 -vv ``` - 捕获`8005`端口的流量,验证是否收到HTTP请求。 --- ### 总结 此错误的核心是 **协议与端口不匹配**,通过检查Tomcat配置和客户端请求行为即可解决。若需进一步排查,可结合日志(`logs/catalina.out`)和网络工具定位具体问题。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值