我的 tomcat 装置在这个目录下:C:\app\tomcat-9.0.56
执行 bin 文件夹下的 startup.bat
时,遇到闪退的问题。
查看 logs 文件夹下的日志文件 catalina.2022-10-29.log
:
遇到如下谬误音讯:
HostConfig.deployDirectory Deployment of web application directory [C:\app\tomcat-9.0.56\webapps\ROOT] has finished in [37] ms
29-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] milliseconds
29-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)
粗心是端口 8005 被占用。
咱们应用命令行 netstat -ano | find "8005"
, 查看是哪一个过程占用了端口 8005.
下图打印后果,-n
选项是打印占用 8005 端口的过程 pid,为 4,状态为 LISTENING
:
在 Windows10 工作管理器里,发现 pid 为 4 的过程为零碎过程:
咱们批改 tomcat 目录下的 server.xml
, 将 shutdown 端口从 8005 更改成 8095 即可:
当初就不会有闪退景象了:
对于 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 所在的中央。