Spring boot 部署为 war文件操作步骤
2018-01-18 16:53
375 查看
第一步:让Application 继承于SpringBootServletInitializer The first step in producing 产生a deployable war file is to provide a SpringBootServletInitializer subclass and override its configure method. This makes use of Spring Framework’s Servlet 3.0 support and allows you to configure your application when it’s launched by the servlet container. Typically通常, you update your application’s main class to extend SpringBootServletInitializer:
@SpringBootApplication
public class Application extends SpringBootServletInitializer {
@Override
protected SpringApplicationBuilder configure(SpringApplicationBuilder application) {
return application.sources(Application.class);
}
public static void main(String[] args) throws Exception {
SpringApplication.run(Application.class, args);
}
}第二步:maven的pom.xml文件文件修改打包类型选择为war<packaging>war</packaging>
The next step is to update your build configuration so that your project produces a war file Rather than而不是 a jar file. If you’re using Maven and using spring-boot-starter-parent (which configures Maven’s war plugin for you) all you need to do is modify pom.xml to change the packaging to war:
<packaging>war</packaging>
If you’re using Gradle, you need to modify build.gradle to apply the war plugin to the project:
apply plugin: 'war'第三步:还是修改pom.xml文件保证下面的依赖存在 <dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-tomcat</artifactId>
<scope>provided</scope>
</dependency>
The final step最后一步 in the process is to ensure确保 that the embedded servlet container doesn’t interfere 干涉with the servlet container to which the war file will be deployed. To do so, you need to mark the embedded servlet container dependency as provided.
If you’re using Maven:
<dependencies>
<!-- … -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-tomcat</artifactId>
<scope>provided</scope>
</dependency>
<!-- … -->
</dependencies>
And if you’re using Gradle:
dependencies {
// …
providedRuntime 'org.springframework.boot:spring-boot-starter-tomcat'
// …
}
If you are using a version of Gradle that supports compile only dependencies (2.12 or later), you should continue to use providedRuntime. Among other limitations局限性, compileOnly dependencies are not on the test classpath so any web-based integration tests will fail.
If you’re using the Spring Boot build tools, marking the embedded servlet container dependency as provided will produce an executable war file with the provided dependencies packaged in a lib-provided directory. This means that, in addition to being deployable to部署到 a servlet container, you can also也可以 run your application using java -jar on the command line.
Take a look at Spring Boot’s sample applications for a Maven-based example of the above-described configuration.
第四步:使用maven打包命令:#maven clean package -Dmaven.test.skip=true
@SpringBootApplication
public class Application extends SpringBootServletInitializer {
@Override
protected SpringApplicationBuilder configure(SpringApplicationBuilder application) {
return application.sources(Application.class);
}
public static void main(String[] args) throws Exception {
SpringApplication.run(Application.class, args);
}
}第二步:maven的pom.xml文件文件修改打包类型选择为war<packaging>war</packaging>
The next step is to update your build configuration so that your project produces a war file Rather than而不是 a jar file. If you’re using Maven and using spring-boot-starter-parent (which configures Maven’s war plugin for you) all you need to do is modify pom.xml to change the packaging to war:
<packaging>war</packaging>
If you’re using Gradle, you need to modify build.gradle to apply the war plugin to the project:
apply plugin: 'war'第三步:还是修改pom.xml文件保证下面的依赖存在 <dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-tomcat</artifactId>
<scope>provided</scope>
</dependency>
The final step最后一步 in the process is to ensure确保 that the embedded servlet container doesn’t interfere 干涉with the servlet container to which the war file will be deployed. To do so, you need to mark the embedded servlet container dependency as provided.
If you’re using Maven:
<dependencies>
<!-- … -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-tomcat</artifactId>
<scope>provided</scope>
</dependency>
<!-- … -->
</dependencies>
And if you’re using Gradle:
dependencies {
// …
providedRuntime 'org.springframework.boot:spring-boot-starter-tomcat'
// …
}
If you are using a version of Gradle that supports compile only dependencies (2.12 or later), you should continue to use providedRuntime. Among other limitations局限性, compileOnly dependencies are not on the test classpath so any web-based integration tests will fail.
If you’re using the Spring Boot build tools, marking the embedded servlet container dependency as provided will produce an executable war file with the provided dependencies packaged in a lib-provided directory. This means that, in addition to being deployable to部署到 a servlet container, you can also也可以 run your application using java -jar on the command line.
Take a look at Spring Boot’s sample applications for a Maven-based example of the above-described configuration.
第四步:使用maven打包命令:#maven clean package -Dmaven.test.skip=true
相关文章推荐
- 将Spring Boot应用打包成可部署的War文件
- Spring Boot 将WAR文件部署到Tomcat
- intellij spring boot 添加热部署步骤及添加之后修改文件没有效果的问题解决
- spring boot打包成war包部署及修改默认配置文件的名称
- Spring Boot创建一个可以部署的war文件
- 通过eclipse把spring boot项目打包成war包并部署到tomcat服务器上的步骤
- SpringBoot基础-用war的方式部署springboot项目
- spring boot打包成war包部署时报404
- spring_boot 发布成war包 ,部署到外部的tomcat
- spring boot war包 在linux下面的tomcat运行步骤
- springboot 多环境(开发、测试、生产)部署配置文件方案
- Spring Boot 打成war包部署到tomcat8.5.20报无法访问
- spring_boot 发布成war包 ,部署到外部的tomcat
- spring boot自定义配置源操作步骤
- spring_boot 发布成war包 ,部署到外部的tomcat
- Springboot打成war包并在tomcat中运行的部署方法
- 构建springboot自动生成mapper文件和dao接口项目的步骤和配置
- IDEA打包spring boot工程为war包并部署到阿里云服务器
- spring boot 自动更新静态文件和后台代码 -- 热部署
- spring boot项目打包成war并在tomcat上运行的步骤