我正在使用Spring Boot和Spring web starter开发一个简单的应用程序。当我使用嵌入式Tomcat服务器(JAR打包)进行测试时,它非常顺利。我需要调试一些东西,所以我认为最好将它作为WAR部署在外部Tomcat服务器上(或者实际上是STS上捆绑的外部Pivotal tc服务器)。
我遵循了Spring Boot's Documentation中所述的程序,在运行应用程序时,我可以看到加载我的控制器,请求等的日志(是吗?Nay。)。一旦容器启动,任何请求都会导致丑陋的404。
我知道Spring Boot会生成符合Servlet 3的容器,因此不应严格要求web.xml
文件。我所要做的就是将我的应用程序的入口点指向一个扩展SpringBootServletInitializer
的类。这是:
package com.company.ci.integration;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.boot.builder.SpringApplicationBuilder;
import org.springframework.boot.context.web.SpringBootServletInitializer;
@SpringBootApplication
public class GitlabWebhookProcessingApplication extends
SpringBootServletInitializer {
public static void main(String[] args) {
SpringApplication.run(GitlabWebhookProcessingApplication.class, args);
}
@Override
protected SpringApplicationBuilder configure(
SpringApplicationBuilder application) {
return application.sources(GitlabWebhookProcessingApplication.class);
}
}
我将这个类指向我的POM文件,如下所示:
<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<start-class>com.chemtech.ci.integration.GitlabWebhookProcessingApplication</start-class>
<java.version>1.7</java.version>
</properties>
正如上面的文档所述,这个应该神奇地工作,我的应用程序将被加载并按预期工作。
啊,这里是日志:
Servlet映射:
2015-06-07 20:21:16.870 INFO 3373 --- [ost-startStop-1] o.s.b.c.e.ServletRegistrationBean : Mapping servlet: 'dispatcherServlet' to [/]
2015-06-07 20:21:16.871 INFO 3373 --- [ost-startStop-1] o.s.b.c.embedded.FilterRegistrationBean : Mapping filter: 'errorPageFilter' to: [/*]
2015-06-07 20:21:16.872 INFO 3373 --- [ost-startStop-1] o.s.b.c.embedded.FilterRegistrationBean : Mapping filter: 'characterEncodingFilter' to: [/*]
2015-06-07 20:21:16.872 INFO 3373 --- [ost-startStop-1] o.s.b.c.embedded.FilterRegistrationBean : Mapping filter: 'hiddenHttpMethodFilter' to: [/*]
控制器动作映射:
2015-06-07 20:21:20.278 INFO 3373 --- [ost-startStop-1] s.w.s.m.m.a.RequestMappingHandlerMapping : Mapped "{[/webhooks/mergeRequestComment],methods=[POST],params=[],headers=[],consumes=[],produces=[],custom=[]}" onto public void com.chemtech.ci.integration.controller.WebhookController.MergeRequestCommentReceiver(java.lang.String,com.chemtech.ci.integration.model.MergeRequestCommentEventRequestBody)
2015-06-07 20:21:20.282 INFO 3373 --- [ost-startStop-1] s.w.s.m.m.a.RequestMappingHandlerMapping : Mapped "{[/error],methods=[],params=[],headers=[],consumes=[],produces=[],custom=[]}" onto public org.springframework.http.ResponseEntity<java.util.Map<java.lang.String, java.lang.Object>> org.springframework.boot.autoconfigure.web.BasicErrorController.error(javax.servlet.http.HttpServletRequest)
2015-06-07 20:21:20.282 INFO 3373 --- [ost-startStop-1] s.w.s.m.m.a.RequestMappingHandlerMapping : Mapped "{[/error],methods=[],params=[],headers=[],consumes=[],produces=[text/html],custom=[]}" onto public org.springframework.web.servlet.ModelAndView org.springframework.boot.autoconfigure.web.BasicErrorController.errorHtml(javax.servlet.http.HttpServletRequest)
重要的是要强调使用带有嵌入式服务器的可执行JAR可以很好地工作。我在这个问题上摸了一会儿,甚至尝试按照其他SO线程的说法做了一些事情:
Spring Boot - custom 404 page with standalone tomcat
我在这里做错了吗? (好吧,我当然是。这是一个纯粹的修辞问题)
非常感谢任何帮助。
谢谢!
答案 0 :(得分:11)
嗯,这是一个相当尴尬的答案,但问题是我忘记了在tc Server / Tomcat上部署战争时,默认情况下根上下文将是WAR的名称。
因此,虽然http://server.ip:8080/controller/method
不起作用,但http://server.ip:8080/war-package-name/controller/method
非常有效。
作为对自己的记录,在星期天晚上工作时永远不要相信自己。
谢谢大家,并希望这有助于将来的某个人!