Tomcat 启动服务控制台报错:Unknown version string [4.0]. Default version will be used.

问题描述

在 web 项目中,tomcat 启动的时候控制台出现了 Unknown version string[4.0] . Default version will be used. 警告。经过一番查阅发现是 web 版本跟 tomcat 版本不匹配导致的。我项目中的 web 版本是 4.0,tomcat 版本是 8.0.5。

版本对应关系

web、jdk、tomcat版本对应关系
web 版本jdk 版本tomcat 版本
version 2.2jdk 1.1tomcat 3.3
version 2.3jdk 1.3tomcat 4.1
version 2.4jdk 1.4tomcat 5.5
version 2.5jdk 1.5tomcat 6.0
version 3.0jdk 1.6tomcat 7.0
version 3.1jdk 1.7tomcat 8.0 或 tomcat 8.5
version 4.0jdk 1.8tomcat 9.0

web.xml 不同版本头

version 2.3


   
  1. <?xml version="1.0" encoding="ISO-8859-1"?>
  2. <!DOCTYPE web-app PUBLIC "-//Sun Microsystems, Inc.//DTD Web Application 2.3//EN"
  3. "http://java.sun.com/dtd/web-app_2_3.dtd">
  4. <web-app>
  5. </web-app>

version 2.4


   
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <web-app id="WebApp_9" version="2.4" xmlns="http://java.sun.com/xml/ns/j2ee"
  3. xmlns:xsi= "http://www.w3.org/2001/XMLSchema-instance"
  4. xsi:schemaLocation= "http://java.sun.com/xml/ns/j2ee http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd">
  5. </web-app>

version 2.5


   
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <web-app xmlns="http://java.sun.com/xml/ns/javaee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  3. xsi:schemaLocation= "http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"
  4. version= "2.5">
  5. </web-app>

version 3.0


   
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <web-app xmlns="http://java.sun.com/xml/ns/javaee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  3. xsi:schemaLocation= "http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd"
  4. version= "3.0">
  5. </web-app>

version 4.0


   
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <web-app xmlns="http://xmlns.jcp.org/xml/ns/javaee"
  3. xmlns:xsi= "http://www.w3.org/2001/XMLSchema-instance"
  4. xsi:schemaLocation= "http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_4_0.xsd"
  5. version= "4.0">
  6. </web-app>

解决方法

知道了报错的原因是由于版本不对应导致的。那么只需要把版本改为对应的就可以了。如果是修改 web 版本的话,只需要把 web.xml 中的版本头替换成对应的版本头即可。 

参考:https://blog.youkuaiyun.com/flyingshadower/article/details/81771955

9-Nov-2025 15:27:21.567 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log Command line argument: -Dorg.apache.catalina.security.SecurityListener.UMASK=0027 19-Nov-2025 15:27:21.567 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log Command line argument: -Dignore.endorsed.dirs= 19-Nov-2025 15:27:21.567 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log Command line argument: -Dcatalina.base=/opt/workplace/tomcat-mdm 19-Nov-2025 15:27:21.567 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log Command line argument: -Dcatalina.home=/opt/workplace/tomcat-mdm 19-Nov-2025 15:27:21.567 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log Command line argument: -Djava.io.tmpdir=/opt/workplace/tomcat-mdm/temp 19-Nov-2025 15:27:21.567 INFO [main] org.apache.catalina.core.AprLifecycleListener.lifecycleEvent The Apache Tomcat Native library which allows using OpenSSL was not found on the java.library.path: [/usr/java/packages/lib/amd64:/usr/lib64:/lib64:/lib:/usr/lib] 19-Nov-2025 15:27:21.700 INFO [main] org.apache.coyote.AbstractProtocol.init Initializing ProtocolHandler ["http-nio-8080"] 19-Nov-2025 15:27:21.711 INFO [main] org.apache.tomcat.util.net.NioSelectorPool.getSharedSelector Using a shared selector for servlet write/read 19-Nov-2025 15:27:21.721 INFO [main] org.apache.catalina.startup.Catalina.load Initialization processed in 494 ms 19-Nov-2025 15:27:21.747 INFO [main] org.apache.catalina.core.StandardService.startInternal Starting service [Catalina] 19-Nov-2025 15:27:21.750 INFO [main] org.apache.catalina.core.StandardEngine.startInternal Starting Servlet engine: [Apache Tomcat/8.5.68] 19-Nov-2025 15:27:21.766 INFO [localhost-startStop-1] org.apache.catalina.startup.HostConfig.deployWAR Deploying web application archive [/opt/workplace/tomcat-mdm/webapps/ROOT.war] 19-Nov-2025 15:27:22.259 WARNING [localhost-startStop-1] org.apache.tomcat.util.descriptor.web.WebXml.setVersion Unknown version string [4.0]. Default version will be used. 19-Nov-2025 15:27:22.261 WARNING [localhost-startStop-1] org.apache.tomcat.util.descriptor.web.WebXml.setVersion Unknown version string [4.0]. Default version will be used. 19-Nov-2025 15:27:27.008 INFO [localhost-startStop-1] org.apache.jasper.servlet.TldScanner.scanJars At least one JAR was scanned for TLDs yet contained no TLDs. Enable debug logging for this logger for a complete list of JARs that were scanned but no TLDs were found in them. Skipping unneeded JARs during scanning can improve startup time and JSP compilation time. 19-Nov-2025 15:27:27.187 INFO [localhost-startStop-1] org.apache.catalina.startup.HostConfig.deployWAR Deployment of web application archive [/opt/workplace/tomcat-mdm/webapps/ROOT.war] has finished in [5,420] ms 19-Nov-2025 15:27:27.188 INFO [localhost-startStop-1] org.apache.catalina.startup.HostConfig.deployDirectory Deploying web application directory [/opt/workplace/tomcat-mdm/webapps/docs] 19-Nov-2025 15:27:27.199 INFO [localhost-startStop-1] org.apache.catalina.startup.HostConfig.deployDirectory Deployment of web application directory [/opt/workplace/tomcat-mdm/webapps/docs] has finished in [11] ms 19-Nov-2025 15:27:27.199 INFO [localhost-startStop-1] org.apache.catalina.startup.HostConfig.deployDirectory Deploying web application directory [/opt/workplace/tomcat-mdm/webapps/examples] 19-Nov-2025 15:27:27.304 INFO [localhost-startStop-1] org.apache.catalina.startup.HostConfig.deployDirectory Deployment of web application directory [/opt/workplace/tomcat-mdm/webapps/examples] has finished in [105] ms 19-Nov-2025 15:27:27.304 INFO [localhost-startStop-1] org.apache.catalina.startup.HostConfig.deployDirectory Deploying web application directory [/opt/workplace/tomcat-mdm/webapps/host-manager] 19-Nov-2025 15:27:27.318 INFO [localhost-startStop-1] org.apache.catalina.startup.HostConfig.deployDirectory Deployment of web application directory [/opt/workplace/tomcat-mdm/webapps/host-manager] has finished in [14] ms 19-Nov-2025 15:27:27.318 INFO [localhost-startStop-1] org.apache.catalina.startup.HostConfig.deployDirectory Deploying web application directory [/opt/workplace/tomcat-mdm/webapps/manager] 19-Nov-2025 15:27:27.331 INFO [localhost-startStop-1] org.apache.catalina.startup.HostConfig.deployDirectory Deployment of web application directory [/opt/workplace/tomcat-mdm/webapps/manager] has finished in [13] ms 19-Nov-2025 15:27:27.337 INFO [main] org.apache.coyote.AbstractProtocol.start Starting ProtocolHandler ["http-nio-8080"] 19-Nov-2025 15:27:27.343 INFO [main] org.apache.catalina.startup.Catalina.start Server startup in 5622 ms 还是启动不了
最新发布
11-20
9-Nov-2025 15:07:39.599 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log Command line argument: -Dignore.endorsed.dirs= 19-Nov-2025 15:07:39.599 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log Command line argument: -Dcatalina.base=/opt/workplace/tomcat-mdm 19-Nov-2025 15:07:39.599 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log Command line argument: -Dcatalina.home=/opt/workplace/tomcat-mdm 19-Nov-2025 15:07:39.599 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log Command line argument: -Djava.io.tmpdir=/opt/workplace/tomcat-mdm/temp 19-Nov-2025 15:07:39.599 INFO [main] org.apache.catalina.core.AprLifecycleListener.lifecycleEvent The Apache Tomcat Native library which allows using OpenSSL was not found on the java.library.path: [/usr/java/packages/lib/amd64:/usr/lib64:/lib64:/lib:/usr/lib] 19-Nov-2025 15:07:39.737 INFO [main] org.apache.coyote.AbstractProtocol.init Initializing ProtocolHandler ["http-nio-8080"] 19-Nov-2025 15:07:39.747 INFO [main] org.apache.tomcat.util.net.NioSelectorPool.getSharedSelector Using a shared selector for servlet write/read 19-Nov-2025 15:07:39.757 INFO [main] org.apache.catalina.startup.Catalina.load Initialization processed in 510 ms 19-Nov-2025 15:07:39.779 INFO [main] org.apache.catalina.core.StandardService.startInternal Starting service [Catalina] 19-Nov-2025 15:07:39.783 INFO [main] org.apache.catalina.core.StandardEngine.startInternal Starting Servlet engine: [Apache Tomcat/8.5.68] 19-Nov-2025 15:07:39.798 INFO [localhost-startStop-1] org.apache.catalina.startup.HostConfig.deployWAR Deploying web application archive [/opt/workplace/tomcat-mdm/webapps/ROOT.war] 19-Nov-2025 15:07:40.289 WARNING [localhost-startStop-1] org.apache.tomcat.util.descriptor.web.WebXml.setVersion Unknown version string [4.0]. Default version will be used. 19-Nov-2025 15:07:40.291 WARNING [localhost-startStop-1] org.apache.tomcat.util.descriptor.web.WebXml.setVersion Unknown version string [4.0]. Default version will be used. 19-Nov-2025 15:07:45.063 INFO [localhost-startStop-1] org.apache.jasper.servlet.TldScanner.scanJars At least one JAR was scanned for TLDs yet contained no TLDs. Enable debug logging for this logger for a complete list of JARs that were scanned but no TLDs were found in them. Skipping unneeded JARs during scanning can improve startup time and JSP compilation time. 19-Nov-2025 15:07:45.254 INFO [localhost-startStop-1] org.apache.catalina.startup.HostConfig.deployWAR Deployment of web application archive [/opt/workplace/tomcat-mdm/webapps/ROOT.war] has finished in [5,455] ms 19-Nov-2025 15:07:45.255 INFO [localhost-startStop-1] org.apache.catalina.startup.HostConfig.deployDirectory Deploying web application directory [/opt/workplace/tomcat-mdm/webapps/docs] 19-Nov-2025 15:07:45.265 INFO [localhost-startStop-1] org.apache.catalina.startup.HostConfig.deployDirectory Deployment of web application directory [/opt/workplace/tomcat-mdm/webapps/docs] has finished in [10] ms 19-Nov-2025 15:07:45.265 INFO [localhost-startStop-1] org.apache.catalina.startup.HostConfig.deployDirectory Deploying web application directory [/opt/workplace/tomcat-mdm/webapps/examples] 19-Nov-2025 15:07:45.370 INFO [localhost-startStop-1] org.apache.catalina.startup.HostConfig.deployDirectory Deployment of web application directory [/opt/workplace/tomcat-mdm/webapps/examples] has finished in [105] ms 19-Nov-2025 15:07:45.371 INFO [localhost-startStop-1] org.apache.catalina.startup.HostConfig.deployDirectory Deploying web application directory [/opt/workplace/tomcat-mdm/webapps/host-manager] 19-Nov-2025 15:07:45.385 INFO [localhost-startStop-1] org.apache.catalina.startup.HostConfig.deployDirectory Deployment of web application directory [/opt/workplace/tomcat-mdm/webapps/host-manager] has finished in [14] ms 19-Nov-2025 15:07:45.385 INFO [localhost-startStop-1] org.apache.catalina.startup.HostConfig.deployDirectory Deploying web application directory [/opt/workplace/tomcat-mdm/webapps/manager] 19-Nov-2025 15:07:45.397 INFO [localhost-startStop-1] org.apache.catalina.startup.HostConfig.deployDirectory Deployment of web application directory [/opt/workplace/tomcat-mdm/webapps/manager] has finished in [12] ms 19-Nov-2025 15:07:45.403 INFO [main] org.apache.coyote.AbstractProtocol.start Starting ProtocolHandler ["http-nio-8080"] 19-Nov-2025 15:07:45.410 INFO [main] org.apache.catalina.startup.Catalina.start Server startup in 5653 ms 为什么项目没起来
11-20
### 原因 Tomcat出现 `Unknown version string [4.0]. Default version will be used.` 警告信息,通常是因为Tomcat在解析某种配置文件(如 `web.xml`)时,遇到了它不识别的版本号。在Tomcat的配置文件中,版本号是用来指定配置文件遵循的规范版本。当Tomcat不支持所指定的版本号时,就会给出该警告,并使用默认版本来处理配置。 例如,在 `web.xml` 文件中,有类似如下的声明: ```xml <web-app xmlns="http://xmlns.jcp.org/xml/ns/javaee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_4_0.xsd" version="4.0"> <!-- 其他配置内容 --> </web-app> ``` 如果当前使用的Tomcat版本不支持 `4.0` 这个版本号,就会触发该警告。 ### 解决办法 - **降低配置文件版本号**:将 `web.xml` 等配置文件中的版本号降低到Tomcat支持的版本。例如,如果Tomcat 8.0 ,可以将版本号改为 `3.1` ,修改后的配置如下: ```xml <web-app xmlns="http://xmlns.jcp.org/xml/ns/javaee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_3_1.xsd" version="3.1"> <!-- 其他配置内容 --> </web-app> ``` - **升级Tomcat版本**:如果应用程序确实需要使用 `4.0` 版本的规范,那么可以考虑将Tomcat升级到支持该版本的版本,比如Tomcat 9.x 及以上版本通常支持Servlet 4.0 规范。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Kaho Wang

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值