Spring Boot war文件在嵌入式Tomcat中运行正常,但在独立的Tomcat中无法运行。
Spring Boot war文件在嵌入式Tomcat中运行正常,但在独立的Tomcat中无法运行。
我想从一个Spring Boot应用程序创建一个war文件,我可以部署到一个独立的Tomcat容器,而不是使用嵌入式的Tomcat。我可以创建war文件并使用"java -jar pdfjs-annotator.war"命令独立运行它,一切都正常。我使用gradle bootRepackage构建了这个应用程序(使用Gradle,Tomcat7,Java 1.7)。但是当我将war文件部署到一个独立的Tomcat并启动它时,应用似乎在日志中没有错误的情况下启动,但是我无法访问任何资源,控制器的URL也无法工作。例如,我的index.html是一个静态html页面,位于src/main/resources/static/index.html下,通常我可以通过localhost:8080/index.html调用它,但当部署到独立的Tomcat时,该页面无法被访问(它位于war文件中的WEB-INF/classes/static/index.html),并且任何类型的控制器映射似乎都无法工作,我得到了一个404错误。build.gradle:
buildscript {
ext {
springBootVersion = '1.2.3.RELEASE'
}
repositories {
mavenCentral()
}
dependencies {
classpath("org.springframework.boot:spring-boot-gradle-plugin:${springBootVersion}")
classpath("io.spring.gradle:dependency-management-plugin:0.5.0.RELEASE")
}
}
apply plugin: 'java'
apply plugin: 'eclipse-wtp'
apply plugin: 'idea'
apply plugin: 'spring-boot'
apply plugin: 'io.spring.dependency-management'
apply plugin: 'war'
war {
baseName = 'pdfjs-annotator'
version = '1.0.0-SNAPSHOT'
}
allprojects {
apply plugin: 'java'
sourceCompatibility = 1.6
targetCompatibility = 1.6
}
repositories {
mavenCentral()
}
configurations {
providedRuntime
}
dependencies {
compile("org.springframework.boot:spring-boot-starter-data-jpa")
compile("org.springframework.boot:spring-boot-starter-data-rest")
compile("org.springframework.boot:spring-boot-starter-web")
runtime("mysql:mysql-connector-java")
providedRuntime("org.springframework.boot:spring-boot-starter-tomcat")
testCompile("org.springframework.boot:spring-boot-starter-test")
compile ('org.hibernate.javax.persistence:hibernate-jpa-2.0-api:1.0.1.Final')
}
eclipse {
classpath {
containers.remove('org.eclipse.jdt.launching.JRE_CONTAINER')
containers 'org.eclipse.jdt.launching.JRE_CONTAINER/org.eclipse.jdt.internal.debug.ui.launcher.StandardVMType/JavaSE-1.7'
}
}
task wrapper(type: Wrapper) {
gradleVersion = '2.3'
}
我的主要应用程序类:
@EnableJpaRepositories
@SpringBootApplication
public class PdfAnnotator extends SpringBootServletInitializer {
public static void main(String[] args) {
SpringApplication.run(PdfAnnotator.class, args);
}
@Override
protected SpringApplicationBuilder configure(SpringApplicationBuilder application) {
return application.sources(PdfAnnotator.class);
}
}
当我查看解压后的war文件时,我确实看到了以下的META-INF/MANIFEST.MF:
Manifest-Version: 1.0
Start-Class: com.mypackage.pdfcomment.PdfAnnotator
Spring-Boot-Version: 1.2.3.RELEASE
Main-Class: org.springframework.boot.loader.WarLauncher
gradle构建过程通常生成两个war文件,一个名为.war,一个名为.war.original - .war是保持正确MANIFEST.MF条目的文件,也是我用来部署到独立的Tomcat的文件。缺少什么?我已经检查了SO上的其他问题:
- spring boot在没有嵌入式Tomcat的情况下创建war文件
- 在Tomcat中部署WAR文件
还有Spring Boot文档,但是找不到有关问题的线索。
* === 更新 === *
我安装了一个全新的Tomcat7,在那里部署了war文件,一切都正常工作。似乎是我之前运行的Tomcat实例/配置有问题。不确定问题具体是什么,但由于现在使用新的Tomcat一切正常,所以不再进一步检查。
问题的原因是Tomcat实例的配置或者JAR包出了问题,可能是由于实例存在的时间较长导致的混乱。通过安装一个全新的Tomcat7实例,问题得到了解决。
解决方法可以参考Spring Boot官方文档中的说明:docs.spring.io/spring-boot/docs/current/reference/htmlsingle/…
虽然我已经按照文档中的说明进行了配置,但是依然没有解决问题。不过,这个问题实际上与Tomcat实例本身有关,而不是应用程序。