创建了一个Spring Boot REST应用程序。
作为Spring启动应用程序运行在日食中将其作为spring boot application
运行时。效果很好。REST API正在使用URL-http://localhost:8080/schools
作为tomcat的WAR部署
我遵循了以下步骤
SpringServletContainerInitializer
@SpringBootApplication
public class RmsBackendApplication extends SpringServletContainerInitializer {
public static void main(String[] args) {
SpringApplication.run(RmsBackendApplication.class, args);
}
}
pom.xml
中添加了起始班级条目 <properties>
<java.version>1.8</java.version>
<start-class>com.codingParkFun.rmsbackend.RmsBackendApplication</start-class>
</properties>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-tomcat</artifactId>
<scope>provided</scope>
</dependency>
很少有文档说重写configure
的SpringServletContainerInitializer
方法。但就我而言,SpringServletContainerInitializer
没有configure
方法。我下载了spring tools 4.0
生成的带有maven install
的程序包。战争包的名称为rms-0.0.1-SNAPSHOT.war
在warcat上部署war软件包(版本9.0.27
]
访问REST API URL-http://localhost:8080/rms-0.0.1-SNAPSHOT/schools
09-Nov-2019 11:13:31.013 INFO [main] org.apache.catalina.core.ApplicationContext.log 1 Spring WebApplicationInitializers detected on classpath
09-Nov-2019 11:13:32.048 INFO [main] org.apache.catalina.core.ApplicationContext.log ContextListener: contextInitialized()
09-Nov-2019 11:13:32.048 INFO [main] org.apache.catalina.core.ApplicationContext.log SessionListener: contextInitialized()
09-Nov-2019 11:13:32.052 INFO [main] org.apache.catalina.core.ApplicationContext.log ContextListener: attributeAdded('StockTicker', 'async.Stockticker@6231bb88')
09-Nov-2019 11:16:44.566 INFO [Thread-4] org.apache.catalina.core.ApplicationContext.log SessionListener: contextDestroyed()
09-Nov-2019 11:16:44.566 INFO [Thread-4] org.apache.catalina.core.ApplicationContext.log ContextListener: contextDestroyed()
09-Nov-2019 11:19:59.676 INFO [main] org.apache.catalina.core.ApplicationContext.log 1 Spring WebApplicationInitializers detected on classpath
09-Nov-2019 11:20:12.722 INFO [main] org.apache.catalina.core.ApplicationContext.log ContextListener: contextInitialized()
09-Nov-2019 11:20:12.723 INFO [main] org.apache.catalina.core.ApplicationContext.log SessionListener: contextInitialized()
09-Nov-2019 11:20:12.728 INFO [main] org.apache.catalina.core.ApplicationContext.log ContextListener: attributeAdded('StockTicker', 'async.Stockticker@2420e962')
09-Nov-2019 11:27:44.515 INFO [main] org.apache.catalina.core.ApplicationContext.log 1 Spring WebApplicationInitializers detected on classpath
09-Nov-2019 11:27:45.490 INFO [main] org.apache.catalina.core.ApplicationContext.log ContextListener: contextInitialized()
09-Nov-2019 11:27:45.490 INFO [main] org.apache.catalina.core.ApplicationContext.log SessionListener: contextInitialized()
09-Nov-2019 11:27:45.494 INFO [main] org.apache.catalina.core.ApplicationContext.log ContextListener: attributeAdded('StockTicker', 'async.Stockticker@1c7da28')
09-Nov-2019 11:38:48.705 INFO [http-nio-8080-exec-7] org.apache.catalina.core.ApplicationContext.log 1 Spring WebApplicationInitializers detected on classpath
不确定应用程序REST API何时无法运行。请指导。
您需要扩展SpringBootServletInitializer,而不是SpringServletContainerInitializer。然后,您可以按照步骤4中的说明重写configure方法,如下所示:
@Override
protected SpringApplicationBuilder configure(SpringApplicationBuilder application) {
return application.sources(RmsBackendApplication.class);
}
希望有帮助!