SPRING BOOT 项目中使用<SCOPE>PROVIDED</SCOPE>打包成WAR到TOMCAT运行出现的问题总结

大家知道 spring boot 项目是自带tomcat 的,但是我们有时候是需要把项目打包成war 然后放到独立的tomcat中运行的,这个时候我们就需要将它自带的tomcat给排除开,这时候我们就可以使用<scope>provided</scope>来实现,我们在pom文件中这样写:

  1.  
    <dependency>
  2.  
    <groupId>org.springframework.boot</groupId>
  3.  
    <artifactId>spring-boot-starter-tomcat</artifactId>
  4.  
    <scope>provided</scope>
  5.  
    </dependency>

      provided 依赖只有在当JDK 或者一个容器已提供该依赖之后才使用。比如说,我们开发了一个web 应用,在编译

classpath 中需要可用的Servlet API 来编译一个servlet,但是我们并不需要打包好的WAR 中包含这个Servlet API,因为这个

Servlet API JAR 可以由我们的应用服务器或者servlet 容器提供。<scope>provided</scope>提供范围的依赖在编译classpath的

时候是可用的,这种依赖不是传递性的,当然也不会被打包到war当中。比如说:

  1.  
    <dependency>
  2.  
    <groupId>javax.servlet</groupId>
  3.  
    <artifactId>servlet-api</artifactId>
  4.  
    <version>3.0-alpha-1</version>
  5.  
    <!--只在编译或测试的时候使用-->
  6.  
    <scope>provided</scope>
  7.  
    </dependency>

     我自己在有一次 spring boot 项目发布到独立的 tomcat 中的时候就出现了由于<scope>provided</scope>引起的问题,我在项目中使用了ehcache缓存,我在复制代码的时候多余地复制了<scope>provided</scope>进去,发布项目启动的时候启动不了,报错,找不到相关的 net.sf.ehcache 类文件,后面一查是因为多了<scope>provided</scope>,将其去掉之后运行成功,这里也做个记录。

  

      最后,我们来看一下scope的几个属性详解:

     1.compile:默认值 他表示被依赖项目需要参与当前项目的编译,还有后续的测试,运行周期也参与其中,是一个比较强的依赖。打包的时候通常需要包含进去。

     2.test:依赖项目仅仅参与测试相关的工作,包括测试代码的编译和执行,不会被打包,例如:junit。

     3.runtime:表示被依赖项目无需参与项目的编译,不过后期的测试和运行周期需要其参与。与compile相比,跳过了编译而已。例如JDBC驱动,适用运行和测试阶段。

     4.provided:打包的时候可以不用包进去,别的设施会提供。事实上该依赖理论上可以参与编译,测试,运行等周期。相当于compile,但是打包阶段做了exclude操作。

    5.system:从参与度来说,和provided相同,不过被依赖项不会从maven仓库下载,而是从本地文件系统拿。需要添加systemPath的属性来定义路径。

posted @ 2020-09-28 10:07  牧之丨  阅读(566)  评论(0编辑  收藏  举报