spring boot的嵌入式服务器(如tomcat、jetty)主要作为servlet容器,仅支持部分java ee规范,如servlet api和jsp。若项目需要使用完整的java ee功能,例如ejb、jms、jta等,则需部署到jboss、weblogic等全功能java ee应用服务器。本文将详细阐述spring boot与java ee的兼容性差异,并指导何时选择嵌入式服务器或外部应用服务器。
Spring Boot以其“约定优于配置”的理念和内嵌式服务器的特性,极大地简化了Java应用的开发与部署。默认情况下,Spring Boot应用会打包成一个可执行的JAR文件,其中包含了应用代码以及一个嵌入式的Servlet容器,例如Apache Tomcat、Eclipse Jetty或Undertow。
这些嵌入式服务器的核心功能是提供一个运行时环境来处理HTTP请求和响应,它们主要实现了Java EE规范中的以下部分:
因此,Spring Boot应用能够轻松构建RESTful API、Web MVC应用以及WebSocket服务。然而,需要明确的是,这些嵌入式服务器本质上是Servlet容器,而非全功能的Java EE应用服务器。
与Servlet容器不同,全功能的Java EE应用服务器(如JBoss/WildFly、Oracle WebLogic、IBM WebSphere、Payara Server等)提供了更广泛、更深入的Java EE规范支持。除了上述Servlet、JSP等Web层技术外,它们还实现了许多企业级核心规范,包括但不限于:
这些规范提供了构建大规模、高可用、高并发企业级应用所需的丰富功能。
理解Spring Boot嵌入式服务器与全功能Java EE应用服务器之间的差异至关重要。

Spring Boot项目默认生成的是一个可执行的JAR文件,其中包含了嵌入式服务器,可以直接通过 java -jar your-app.jar 命令运行。这是Spring Boot推荐的部署方式,尤其适用于容器化和微服务架构。
然而,如果确实需要将Spring Boot应用部署到外部的全功能Java EE应用服务器(如JBoss),则需要将项目打包成WAR(Web Application Archive)文件。
如何将Spring Boot项目打包为WAR文件:
修改pom.xml:
war org.springframework.boot spring-boot-starter-weborg.springframework.boot spring-boot-starter-tomcatprovided org.springframework.boot spring-boot-maven-plugin
修改主应用类:
import org.springframework.boot.builder.SpringApplicationBuilder;
import org.springframework.boot.web.servlet.support.SpringBootServletInitializer;
@SpringBootApplication
public class MyApplication extends SpringBootServletInitializer {
public static void main(String[] args) {
SpringApplication.run(MyApplication.class, args);
}
@Override
protected SpringApplicationBuilder configure(SpringApplicationBuilder application) {
return application.sources(MyApplication.class);
}
}完成这些修改后,执行 mvn package 命令,将会在 target 目录下生成一个WAR文件,你可以将其部署到JBoss等应用服务器。
Spring Boot的嵌入式服务器为现代Web应用和微服务提供了高效、便捷的开发和部署体验,它支持Java EE规范中的Servlet、JSP等核心Web技术。然而,它并非全功能的Java EE应用服务器,不提供EJB、JMS、JTA等所有企业级规范的完整实现。
在选择技术栈时,开发者应根据项目的具体需求进行权衡:
理解这些差异有助于做出明智的技术决策,从而构建出既符合业务需求又高效可靠的应用程序。