windows启微服务端口被占用情况的排查与解决方法

问题如下

复制代码
Failed to start connector [Connector[HTTP/1.1-19200]]

org.apache.catalina.LifecycleException: Failed to start component [Connector[HTTP/1.1-19200]]
	at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:167) ~[tomcat-embed-core-8.5.32.jar:8.5.32]
	at org.apache.catalina.core.StandardService.addConnector(StandardService.java:225) ~[tomcat-embed-core-8.5.32.jar:8.5.32]
	at org.springframework.boot.web.embedded.tomcat.TomcatWebServer.addPreviouslyRemovedConnectors(TomcatWebServer.java:256) [spring-boot-2.0.4.RELEASE.jar:2.0.4.RELEASE]
	at org.springframework.boot.web.embedded.tomcat.TomcatWebServer.start(TomcatWebServer.java:198) [spring-boot-2.0.4.RELEASE.jar:2.0.4.RELEASE]
	at org.springframework.boot.web.servlet.context.ServletWebServerApplicationContext.startWebServer(ServletWebServerApplicationContext.java:300) [spring-boot-2.0.4.RELEASE.jar:2.0.4.RELEASE]
	at org.springframework.boot.web.servlet.context.ServletWebServerApplicationContext.finishRefresh(ServletWebServerApplicationContext.java:162) [spring-boot-2.0.4.RELEASE.jar:2.0.4.RELEASE]
	at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:553) [spring-context-5.0.8.RELEASE.jar:5.0.8.RELEASE]
	at org.springframework.boot.web.servlet.context.ServletWebServerApplicationContext.refresh(ServletWebServerApplicationContext.java:140) [spring-boot-2.0.4.RELEASE.jar:2.0.4.RELEASE]
	at org.springframework.boot.SpringApplication.refresh(SpringApplication.java:762) [spring-boot-2.0.4.RELEASE.jar:2.0.4.RELEASE]
	at org.springframework.boot.SpringApplication.refreshContext(SpringApplication.java:398) [spring-boot-2.0.4.RELEASE.jar:2.0.4.RELEASE]
	at org.springframework.boot.SpringApplication.run(SpringApplication.java:330) [spring-boot-2.0.4.RELEASE.jar:2.0.4.RELEASE]
	at org.springframework.boot.SpringApplication.run(SpringApplication.java:1258) [spring-boot-2.0.4.RELEASE.jar:2.0.4.RELEASE]
	at org.springframework.boot.SpringApplication.run(SpringApplication.java:1246) [spring-boot-2.0.4.RELEASE.jar:2.0.4.RELEASE]
	at com.sgcc.xjgc.platform.material.MaterialAppMain.main(MaterialAppMain.java:24) [classes/:na]
	at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) ~[na:1.8.0_261]
	at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) ~[na:1.8.0_261]
	at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) ~[na:1.8.0_261]
	at java.lang.reflect.Method.invoke(Method.java:498) ~[na:1.8.0_261]
	at org.springframework.boot.devtools.restart.RestartLauncher.run(RestartLauncher.java:49) [spring-boot-devtools-2.0.4.RELEASE.jar:2.0.4.RELEASE]
Caused by: org.apache.catalina.LifecycleException: Protocol handler start failed
	at org.apache.catalina.connector.Connector.startInternal(Connector.java:1020) ~[tomcat-embed-core-8.5.32.jar:8.5.32]
	at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:150) ~[tomcat-embed-core-8.5.32.jar:8.5.32]
	... 18 common frames omitted
Caused by: java.net.BindException: Address already in use: bind
	at sun.nio.ch.Net.bind0(Native Method) ~[na:1.8.0_261]
	at sun.nio.ch.Net.bind(Net.java:444) ~[na:1.8.0_261]
	at sun.nio.ch.Net.bind(Net.java:436) ~[na:1.8.0_261]
	at sun.nio.ch.ServerSocketChannelImpl.bind(ServerSocketChannelImpl.java:225) ~[na:1.8.0_261]
	at sun.nio.ch.ServerSocketAdaptor.bind(ServerSocketAdaptor.java:74) ~[na:1.8.0_261]
	at org.apache.tomcat.util.net.NioEndpoint.bind(NioEndpoint.java:210) ~[tomcat-embed-core-8.5.32.jar:8.5.32]
	at org.apache.tomcat.util.net.AbstractEndpoint.start(AbstractEndpoint.java:1150) ~[tomcat-embed-core-8.5.32.jar:8.5.32]
	at org.apache.coyote.AbstractProtocol.start(AbstractProtocol.java:591) ~[tomcat-embed-core-8.5.32.jar:8.5.32]
	at org.apache.catalina.connector.Connector.startInternal(Connector.java:1018) ~[tomcat-embed-core-8.5.32.jar:8.5.32]
	... 19 common frames omitted

根据错误信息,问题出现在尝试启动服务器时,遇到了端口已被占用的情况(Address already in use: bind)。这意味着尝试绑定的端口 19200 已经被另一个进程占用了。

解决方案

1. 查找占用端口的进程

首先,需要找到哪个进程占用了端口 19200。在 Windows 上,可以使用以下命令来查找占用端口的进程:

cmd 复制代码
netstat -ano | findstr 19200

这将列出所有监听在端口 19200 的连接及其对应的进程 ID。

然后,使用以下命令根据进程 ID 查找对应的进程名称:

cmd 复制代码
tasklist | findstr <进程ID>

例如,如果端口被进程 ID 为 1234 的进程占用,命令如下:

cmd 复制代码
tasklist | findstr 1234
2. 终止占用端口的进程

如果确认该进程不是必要的,可以终止它。在 Windows 上,可以使用以下命令杀死进程:

cmd 复制代码
taskkill /F /PID <进程ID>

例如,如果进程 ID 为 1234,命令如下:

cmd 复制代码
taskkill /F /PID 1234
3. 更改应用端口

如果无法终止占用端口的进程,或者希望避免此类冲突,可以更改应用程序监听的端口。在 Spring Boot 应用中,在 application.propertiesapplication.yml 文件中更改端口号:

示例 application.properties
properties 复制代码
server.port=19201
示例 application.yml
yaml 复制代码
server:
  port: 19201
4. 检查防火墙设置

确保防火墙设置没有阻止端口 19200 的使用。如果是防火墙问题,可以暂时关闭防火墙进行测试:

cmd 复制代码
netsh advfirewall set allprofiles state off

测试完成后,请记得重新开启防火墙:

cmd 复制代码
netsh advfirewall set allprofiles state on

示例步骤

  1. 查找占用端口的进程

    cmd 复制代码
    netstat -ano | findstr 19200
  2. 查找对应进程名称

    cmd 复制代码
    tasklist | findstr <进程ID>
  3. 终止占用端口的进程

    cmd 复制代码
    taskkill /F /PID <进程ID>
  4. 更改应用端口

    properties 复制代码
    server.port=19201
  5. 重新启动应用

    确保更改端口后重新启动应用。

相关推荐
呉師傅几秒前
【使用技巧】Adobe Photoshop 2024调整缩放与布局125%后出现点菜单项漂移问题的简单处理
运维·服务器·windows·adobe·电脑·photoshop
是码龙不是码农3 分钟前
支付防重复下单|5 种幂等性设计方案(从初级到架构级)
java·架构·幂等性
云边有个稻草人7 分钟前
CANN异构架构:以ops-nn为翼,驱动AIGC底层计算新突破
架构·aigc
心疼你的一切8 分钟前
模态交响:CANN驱动的跨模态AIGC统一架构
数据仓库·深度学习·架构·aigc·cann
晚霞的不甘33 分钟前
CANN × ROS 2:为智能机器人打造实时 AI 推理底座
人工智能·神经网络·架构·机器人·开源
jiet_h1 小时前
后端 Verticle 架构实战:用 NeonBeeDeployable 推送一条通知
架构
程序猿追1 小时前
CANN ops-math仓库解读 数学算子的底层支撑与高性能实现
人工智能·架构
芷栀夏1 小时前
从 CANN 开源项目看现代爬虫架构的演进:轻量、智能与统一
人工智能·爬虫·架构·开源·cann
梦帮科技1 小时前
OpenClaw 桥接调用 Windows MCP:打造你的 AI 桌面自动化助手
人工智能·windows·自动化
程序猿追2 小时前
深度剖析 CANN ops-nn 算子库:架构设计、演进与代码实现逻辑
人工智能·架构