likes
comments
collection
share

tomcat 端口 8005 被 windows 系统服务占用导致启动闪退的问题

作者站长头像
站长
· 阅读数 21

我的 tomcat 安装在这个目录下:C:\app\tomcat-9.0.56

执行 bin 文件夹下的 startup.bat 时,遇到闪退的问题。

查看 logs 文件夹下的日志文件 catalina.2022-10-29.log

tomcat 端口 8005 被 windows 系统服务占用导致启动闪退的问题

遇到如下错误消息:

HostConfig.deployDirectory Deployment of web application directory [C:\app\tomcat-9.0.56\webapps\ROOT] has finished in [37] ms29-Oct-2022 17:21:47.262 INFO [main] org.apache.coyote.AbstractProtocol.start Starting ProtocolHandler ["http-nio-8080"]29-Oct-2022 17:21:47.951 INFO [main] org.apache.catalina.startup.Catalina.start Server startup in [2830] milliseconds29-Oct-2022 17:21:47.963 SEVERE [main] org.apache.catalina.core.StandardServer.await Failed to create server shutdown socket on address [localhost] and port [8005] (base port [8005] and offset [0])
java.net.BindException: Address already in use: NET_Bind
    at java.base/java.net.PlainSocketImpl.bind0(Native Method)
    at java.base/java.net.PlainSocketImpl.socketBind(PlainSocketImpl.java:132)
    at java.base/java.net.AbstractPlainSocketImpl.bind(AbstractPlainSocketImpl.java:452)

tomcat 端口 8005 被 windows 系统服务占用导致启动闪退的问题

大意是端口 8005 被占用。

tomcat 端口 8005 被 windows 系统服务占用导致启动闪退的问题

我们使用命令行 netstat -ano | find "8005", 查看是哪一个进程占用了端口 8005.

下图打印结果,-n 选项是打印占用 8005 端口的进程 pid,为 4,状态为 LISTENING

tomcat 端口 8005 被 windows 系统服务占用导致启动闪退的问题在 Windows10 任务管理器里,发现 pid 为 4 的进程为系统进程:

tomcat 端口 8005 被 windows 系统服务占用导致启动闪退的问题

tomcat 端口 8005 被 windows 系统服务占用导致启动闪退的问题

我们修改 tomcat 目录下的 server.xml, 将 shutdown 端口从 8005 更改成 8095 即可:

tomcat 端口 8005 被 windows 系统服务占用导致启动闪退的问题

现在就不会有闪退现象了:tomcat 端口 8005 被 windows 系统服务占用导致启动闪退的问题

关于 Tomcat

Apache Tomcat® 软件是 Jakarta Servlet、Jakarta Server Pages、Jakarta Expression Language、Jakarta WebSocket、Jakarta Annotations 和 Jakarta Authentication 规范的开源实现。 这些规范是 Jakarta EE 平台的一部分。

Jakarta EE 平台是 Java EE 平台的演进。 Tomcat 10 及更高版本实现了作为 Jakarta EE 一部分开发的规范。 Tomcat 9 和更早的版本实现了作为 Java EE 的一部分开发的规范。

tomcat 的重要文件夹:

  • /bin - 启动、关闭和其他脚本。 .sh 文件(适用于 Unix 系统)是 .bat 文件(适用于 Windows 系统)的功能副本。 由于 Win32 命令行缺少某些功能,因此这里有一些附加文件。
  • /conf - 配置文件和相关的 DTD。 这里最重要的文件是 server.xml。 它是容器的主要配置文件。
  • /logs - 默认情况下,日志文件在此处。
  • /webapps - 这是我们从本地部署 web 应用到 tomcat 所在的地方。