java.net.BindException: Address already in use: JVM_Bind :8080 解决方法

解决Tomcat端口冲突
本文介绍了解决Tomcat与Oracle占用相同8080端口的问题,通过修改Tomcat安装目录下的server.xml文件,更改端口号来避免冲突。

java.net.BindException: Address already in use: JVM_Bind <null>:8080

   at org.apache.tomcat.util.net.JIoEndpoint.init(JIoEndpoint.java:549)
    at org.apache.tomcat.util.net.JIoEndpoint.start(JIoEndpoint.java:565)
    at org.apache.coyote.http11.Http11Protocol.start(Http11Protocol.java:203)
    at org.apache.catalina.connector.Connector.start(Connector.java:1087)
    at org.apache.catalina.core.StandardService.start(StandardService.java:534)
    at org.apache.catalina.core.StandardServer.start(StandardServer.java:710)
    at org.apache.catalina.startup.Catalina.start(Catalina.java:581)
    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:289)
    at org.apache.catalina.startup.Bootstrap.main(Bootstrap.java:414)
Caused by: 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 java.net.ServerSocket.<init>(ServerSocket.java:141)
    at org.apache.tomcat.util.net.DefaultServerSocketFactory.createSocket(DefaultServerSocketFactory.java:50)
    at org.apache.tomcat.util.net.JIoEndpoint.init(JIoEndpoint.java:538)
    ... 12 more
2011-1-5 9:59:04 org.apache.catalina.startup.Catalina start
严重: Catalina.start:
LifecycleException:  service.getName(): "Catalina";  Protocol handler start failed: java.net.BindException: Address already in use: JVM_Bind <null>:8080
    at org.apache.catalina.connector.Connector.start(Connector.java:1094)
    at org.apache.catalina.core.StandardService.start(StandardService.java:534)
    at org.apache.catalina.core.StandardServer.start(StandardServer.java:710)
    at org.apache.catalina.startup.Catalina.start(Catalina.java:581)
    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:289)
    at org.apache.catalina.startup.Bootstrap.main(Bootstrap.java:414)

 

以上问题的出现是因为TOMCAT和Oracle同时都占用了8080端口,需要在TOMCAT安装目录下将conf文件夹下的server.xml文件所有8080,更改为其它端口号。

java.net.BindException: Address already in use: JVM_Bind是一个常见的异常,意味着在绑定一个地址和端口时发生了冲突,因为该地址和端口已经被其他进程占用了。这个异常通常在网络编程中使用socket时出现,尤其是在同时运行多个程序或服务监听相同的地址和端口时。 通常有几种原因导致这个问题的发生。一种可能是在同一台计算机上运行了多个相同的服务或程序,它们试图在相同的端口上进行监听。在这种情况下,解决方法是找到冲突的进程并停止它们,或者为每个进程分配不同的端口。 另一种可能是之前的程序没有正确释放绑定的端口,导致该端口仍然处于占用状态。解决这个问题的方法是等待一段时间,让操作系统自动释放该端口,或者手动杀死占用该端口的进程。 此外,还有可能是防火墙或安全软件阻止了程序对特定端口的访问。在这种情况下,您可以尝试禁用防火墙或更新安全软件的设置来允许程序访问所需的端口。 总结起来,java.net.BindException: Address already in use: JVM_Bind异常意味着在绑定地址和端口时发生了冲突,可能是因为多个程序或服务同时监听相同的地址和端口,或者之前的程序没有正确释放绑定的端口,也可能是防火墙或安全软件阻止了程序对端口的访问。解决方法包括找到冲突的进程并停止它们、等待操作系统自动释放端口、手动杀死占用端口的进程,或者更新安全设置允许程序访问所需的端口。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值