Spring Boot:内置tomcat启动和外部tomcat部署总结

本文详细介绍了Spring Boot项目如何使用内置Tomcat启动,包括IDEA启动、命令行启动和jar包启动,以及如何配置Servlet容器和Tomcat属性。此外,还阐述了外置Tomcat部署的步骤,包括继承SpringBootServletInitializer、修改pom.xml配置、打包war文件,并强调了配置过程中的关键点和注意事项,如scope的使用、context-path的设置等。
摘要由CSDN通过智能技术生成

参考链接: https://blog.csdn.net/fanshukui/article/details/80258793

springboot的web项目的启动主要分为:

一.使用内置tomcat启动

启动方式:

1、IDEA中main函数启动

2、mvn springboot-run 命令

3、java -jar XXX.jar

使用第三种时,为保证服务在后台运行,会使用nohup ,例如:

nohup java -jar -Xms128m -Xmx128m -Xss256k -XX:+PrintGCDetails -XX:+PrintHeapAtGC -Xloggc:/data/log/web-gc.log web.jar >/data/log/web.log &

配置内置tomcat属性:

关于Tomcat的属性都在org.springframework.boot.autoconfigure.web.ServerProperties配置类中做了定义,我们只需在application.properties配置属性做配置即可。通用的Servlet容器配置都已”server”左右前缀,而Tomcat特有配置都以”server.tomcat”作为前缀。下面举一些常用的例子。

配置Servlet容器:

复制代码

 
  1. #配置程序端口,默认为8080

  2. server.port= 8080

  3. #用户绘画session过期时间,以秒为单位

  4. server.session.timeout=

  5. # 配置默认访问路径,默认为/

  6. server.context-path=

复制代码

 

配置Tomcat:

 
  1. # 配置Tomcat编码,默认为UTF-8

  2. server.tomcat.uri-encoding=UTF-8

  3. # 配置最大线程数

  4. server.tomcat.max-threads=1000

 

二.使用外置tomcat部署

配置步骤:

1、继承SpringBootServletInitializer

  • 外部容器部署的话,就不能依赖于Application的main函数了,而是要以类似于web.xml文件配置的方式来启动Spring应用上下文,此时我们需要在启动类中继承SpringBootServletInitializer并实现configure方法:

复制代码

 
  1. package com.zjt.chapter05;

  2.  
  3. import org.springframework.boot.SpringApplication;

  4. import org.springframework.boot.autoconfigure.SpringBootApplication;

  5. import org.springframework.boot.builder.SpringApplicationBuilder;

  6. import org.springframework.boot.web.support.SpringBootServletInitializer;

  7.  
  8. @SpringBootApplication

  9. public class Chapter05Application extends SpringBootServletInitializer {

  10.  
  11. @Override

  12. protected SpringApplicationBuilder configure(SpringApplicationBuilder application) {

  13. return application.sources(Chapter05Application.class);

  14. }

  15.  
  16. public static void main(String[] args) {

  17. SpringApplication.run(Chapter05Application.class, args);

  18. }

  19. }

复制代码

 

这个类的作用与在web.xml中配置负责初始化Spring应用上下文的监听器作用类似,只不过在这里不需要编写额外的XML文件了。

 2、pom.xml修改tomcat相关的配置

  首先介绍下maven中scope依赖范围的概念,因为后续涉及到这个会有问题。

  依赖范围就是用来控制依赖和三种classpath(编译classpath,测试classpath、运行classpath)的关系,Maven有如下几种依赖范围:

  • compile:编译依赖范围。如果没有指定,就会默认使用该依赖范围。使用此依赖范围的Maven依赖,对于编译、测试、运行三种classpath都有效。典型的例子是spring-code,在编译、测试和运行的时候都需要使用该依赖。

  • test: 测试依赖范围。使用次依赖范围的Maven依赖,只对于测试classpath有效,在编译主代码或者运行项目的使用时将无法使用此依赖。典型的例子是Jnuit,它只有在编译测试代码及运行测试的时候才需要。

  • provided:已提供依赖范围。使用此依赖范围的Maven依赖,对于编译和测试classpath有效,但在运行时候无效。典型的例子是servlet-api,编译和测试项目的时候需要该依赖,但在运行项目的时候,由于容器以及提供,就不需要Maven重复地引入一遍。

 

 

如果要将最终的打包形式改为war的话,还需要对pom.xml文件进行修改,因为spring-boot-starter-web中包含内嵌的tomcat容器,所以直接部署在外部容器会冲突报错。这里有两种方法可以解决,如下

方法一:

复制代码

 
  1. <dependency>

  2. <groupId>org.springframework.boot</groupId>

  3. <artifactId>spring-boot-starter-web</artifactId>

  4. <exclusions>

  5. <exclusion>

  6. <groupId>org.springframework.boot</groupId>

  7. <artifactId>spring-boot-starter-tomcat</artifactId>

  8. </exclusion>

  9. </exclusions>

  10. </dependency>

复制代码

 

在这里需要移除对嵌入式Tomcat的依赖,这样打出的war包中,在lib目录下才不会包含Tomcat相关的jar包,否则将会出现启动错误。

还有一个很关键的关键点,就是tomcat-embed-jasper中scope必须是provided。

 
  1. <dependency>

  2. <groupId>org.apache.tomcat.embed</groupId>

  3. <artifactId>tomcat-embed-jasper</artifactId>

  4. <scope>provided</scope>

  5. </dependency>

 

因为SpringBootServletInitializer需要依赖 javax.servlet,而tomcat-embed-jasper下面的tomcat-embed-core中就有这个javax.servlet,如果没用provided,最终打好的war里面会有servlet-api这个jar,这样就会跟tomcat本身的冲突了。这个关键点同样适应于下面说的第二种方法。

方法二:

直接添加如下配置即可:

复制代码

 
  1. <!--部署成war包时开启↓↓↓↓-->

  2. <dependency>

  3. <groupId>org.springframework.boot</groupId>

  4. <artifactId>spring-boot-starter-tomcat</artifactId>

  5. <scope>provided</scope>

  6. </dependency>

  7. <dependency>

  8. <groupId>org.apache.tomcat.embed</groupId>

  9. <artifactId>tomcat-embed-jasper</artifactId>

  10. <scope>provided</scope>

  11. </dependency>

  12. <!--部署成war包时开启↑↑↑↑-->

复制代码

 

provided的作用上面已经介绍的很透彻了,这里就不啰嗦了,这种方式的好处是,打包的war包同时适合java -jar命令启动以及部署到外部容器中。

 

3、由jar变成war

<packaging>war</packaging>

4、注意的问题

此时打成的包的名称应该和application.properties的 
server.context-path=/test

保持一致

 
  1. <build>

  2. <finalName>test</finalName>

  3. </build>

如果不一样发布到tomcat的webapps下上下文会变化。

 

5、通过命令打包java项目war包

  5.1 控制台进入项目webapp文件夹下,执行命令: jar -cvf   * .war   ./*

jar -cvf center_new.war ./*

 5.2 执行完毕,在该文件夹下生成 *.war包

 

6、Maven命令打包war及常用基本命令

参考链接: https://blog.csdn.net/rentian1/article/details/80746850 

6.1 先把命令行切换到Maven项目的根目录,比如:/d/xxxwork/java/maven-test,然后执行命令:mvn clean package

6.2 常用mvn 命令

mvn -v //查看版本  
mvn archetype:create //创建 Maven 项目  
mvn compile //编译源代码  
mvn test-compile //编译测试代码  
mvn test //运行应用程序中的单元测试  
mvn site //生成项目相关信息的网站  
mvn package //依据项目生成 jar 文件  
mvn install //在本地 Repository 中安装 jar  
mvn -Dmaven.test.skip=true //忽略测试文档编译  
mvn clean //清除目标目录中的生成结果  
mvn clean compile //将.java类编译为.class文件  
mvn clean package //进行打包  
mvn clean test //执行单元测试  
mvn clean deploy //部署到版本仓库  
mvn clean install //使其他项目使用这个jar,会安装到maven本地仓库中  
mvn archetype:generate //创建项目架构  
mvn dependency:list //查看已解析依赖  
mvn dependency:tree //看到依赖树  
mvn dependency:analyze //查看依赖的工具  
mvn help:system //从中央仓库下载文件至本地仓库  
mvn help:active-profiles //查看当前激活的profiles  
mvn help:all-profiles //查看所有profiles  
mvn help:effective -pom //查看完整的pom信息 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值