tomcat错误信息解决方案【严重:StandardServer.await: create[8005]】 (2012-05-03 08:33:34)转载▼...

tomcat错误信息解决方案【严重:StandardServer.await: create[8005]】

(2012-05-03 08:33:34)
标签: 

杂谈

 
错误信息:
 
严重: StandardServer.await: create[8005]: 
java.net.BindException: Address already in use: JVM_Bind
        at java.net.PlainSocketImpl.socketBind(Native Method)
at java.net.PlainSocketImpl.bind(PlainSocketImpl.java:359)
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:630)
at org.apache.catalina.startup.Catalina.start(Catalina.java:590)
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)
 
1.独立运行的tomcat.exe没有关闭,关闭tomcat图标并结束掉tomcat进程。
2.安装了其他的软件占用了8080端口,tomcat安装默认的端口是8080,解决方案一,更改tomcat的端口,用editplus或者写字板打开conf\service.xml:
   <Connector port="8080" protocol="HTTP/1.1" connectionTimeout="20000" redirectPort="8443" />
  
    更改8080为其他端口号
 或者 打开cmd命令提示符,输入 netstat -ano  找到8080端口占用的pid号 输入taskkill /pid xxxx  xxxx为PID号。关闭这个占用端口即可

StandardServer.await: create[8005]java.net.BindException: Address already in use: JVM_Bind错误

分类: JAVA 2091人阅读 评论(0) 收藏 举报

在给客户装完系统配置好环境后,启动Tomcat6后报错“ StandardServer.await: create[8005]java.net.BindException: Address already in use: JVM_Bind”,原来是Tomcat8005端口被其他进程占用,8005端口是用来关闭TOMCAT服务的端口,解决的方法如下

1.方法一,修改tomcat/conf/server.xml文件

打开server.xml

将<Server port="8005" shutdown="SHUTDOWN">中8005改成不常用的端口号即可,比如8088

2.方法二,将占用8005的进程强行结束

(1) 在“运行”中输入CMD
(2)在启动的窗口中输入netstat -ano,就可以看到所有端口占用的情况,记下占用8005端口的程序的PID
(3)打开“任务管理器”,点击菜单栏的“查看”,再点击“选择列”,选上“PID(进程标识符)”或者用tasklist命令查看
(4)在进程中找个相应的PID值,结束进程即可

linux下的关闭进程命令

 

  (2009-11-03 11:06:51)
标签: 

杂谈

分类: Linux
杀死进程最安全的方法是单纯使用kill命令,不加修饰符,不带标志。
首先使用ps -ef命令确定要杀死进程的PID,然后输入以下命令:
# kill -pid
注释:标准的kill命令通常都能达到目的。终止有问题的进程,并把进程的资源释放给系统。然而,如果进程启动了子进程,只杀死父进程,子进程仍在运行,因此仍消耗资源。为了防止这些所谓的“僵尸进程”,应确保在杀死父进程之前,先杀死其所有的子进程。
确定要杀死进程的PID或PPID
# ps -ef | grep httpd
以优雅的方式结束进程
# kill -l PID
-l选项告诉kill命令用好像启动进程的用户已注销的方式结束进程。当使用该选项时,kill命令也试图杀死所留下的子进程。但这个命令也不是总能成功--或许仍然需要先手工杀死子进程,然后再杀死父进程。
TERM信号
给父进程发送一个TERM信号,试图杀死它和它的子进程。
# kill -TERM PPID
killall命令
killall命令杀死同一进程组内的所有进程。其允许指定要终止的进程的名称,而非PID。
# killall httpd
停止和重启进程
有时候只想简单的停止和重启进程。如下:
# kill -HUP PID
该命令让Linux和缓的执行进程关闭,然后立即重启。在配置应用程序的时候,这个命令很方便,在对配置文件修改后需要重启进程时就可以执行此命令。
绝杀 kill -9 PID
同意的 kill -s SIGKILL
这个强大和危险的命令迫使进程在运行时突然终止,进程在结束后不能自我清理。危害是导致系统资源无法正常释放,一般不推荐使用,除非其他办法都无效。
当使用此命令时,一定要通过ps -ef确认没有剩下任何僵尸进程。只能通过终止父进程来消除僵尸进程。如果僵尸进程被init收养,问题就比较严重了。杀死init进程意味着关闭系统。
如果系统中有僵尸进程,并且其父进程是init,而且僵尸进程占用了大量的系统资源,那么就需要在某个时候重启机器以清除进程表了。

 

<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、付费专栏及课程。

余额充值