部署Spring-boot

SpringBoot应用程序有多种构建和运行方式(开发环境)

  • 在IDE中运行应用程序(涉及Spring ToolSuite或IntelliJ IDEA)
  • 使用Maven的 spring-boot:run 或Gradle的 bootRun ,在命令行里运行。
  • 使用Maven或Gradle生成可运行的JAR文件,随后在命令行中运行
  • 使用Spring Boot CLI在命令行中运行Groovy脚本
  • 使用Spring Boot CLI来生成可运行的JAR文件,随后在命令行中运行

部署到生产环境

  • 修改pom.xml, 将jar改为 war
    war
    
    这样就能生成WAR文件了。但如果WAR文件里没有启用Spring MVC DispatcherServletweb.xml 文件或者Servlet初始化类,这个WAR文件就一无是处。
    Spring Boot提供的 SpringBootServletInitializer 是一个支持
    Spring Boot的 Spring WebApplicationInitializer 实 现 。除了 配置 Spring 的 Dispatcher-Servlet , SpringBootServletInitializer 还会在Spring应用程序上下文里查找 FilterServletServletContextInitializer类型的Bean,把它们绑定到Servlet容器里.
    要使用 SpringBootServletInitializer ,只需创建一个子类,覆盖 configure() 方法来指定Spring配置类
    注意: pom.xml中的加载的 jdk版本是:
    
        UTF-8
        UTF-8
        1.8
    
  • 修改Spring Boot启动类, 让其继承 SpringBootServletInitializer 并重写configure方法如下:
package com.example.readinglist;

import groovy.lang.Grab;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.boot.builder.SpringApplicationBuilder;
import org.springframework.boot.web.support.SpringBootServletInitializer;

/**
 * Spring Boot 启动类
 */
@SpringBootApplication
//@Grab("spring-boot-starter-remote-shell")
public class DemoApplication extends SpringBootServletInitializer{

    @Override
    protected SpringApplicationBuilder configure(SpringApplicationBuilder application) {
        return application.sources(DemoApplication.class);
    }

    public static void main(String[] args) {
        SpringApplication.run(DemoApplication.class, args);
    }
}
  • 命令行下到项目的根目录, 打包

     cd /home/lxf/test/readinglist/
     //-Dmaven.test.skip=true代表跳过单元测试
     mvn package -Dmaven.test.skip=true
    

    成功后会在 /home/lxf/test/readinglist/target/目录生成readinglist-0.0.1-SNAPSHOT.war

  • 将生成的war包copy到tomcatwebapps 目录

  • 不用重启tomcat, 直接访问:http://localhost:8081/readinglist-0.0.1-SNAPSHOT/hello
    readinglist-0.0.1-SNAPSHOT.war可以自行修改为任意文件名, 比如: 修改为readinglist.war, 那么访问的路径就是: http://localhost:8081/hello
    注意: 以上8081端口是我tomcat配置的端口,并不是在application.yml配置的服务端口, application.yml中配置的端口是为了Spring Boot内嵌tomcat配置的,与打包后部署到tomcat并无任何关系;

  • 访问后会自动解压war包, 解压后的内容如下:

    部署Spring-boot_第1张图片
    image.png

    其中 org 目录下是Spring Boot相关文件

  • 访问会出现404, 是因为我的tomcat配置的是加载jdk-1.7版本, 而Spring Boot配置的是1.8, 所以要修改tomcat对应的 jdk 版本:
    /usr/local/tomcat/bin/catalina.sh/usr/local/tomcat/bin/setclasspath.sh两个文件起始部分填入

    JAVA_HOME=/usr/lib/jvm/jdk1.8.0_131
    JRE_HOME=/usr/lib/jvm/jdk1.8.0_131/jre
    

    重启tomcat即可, 在重启的时候会看到tomcat加载jdk的版本:


    image.png
  • 还有一点值得注意
    我们在构建的是WAR文件,这个文件仍旧可以脱离应用服务器直
    接运行。如果你没有删除 DemoApplication 里的 main() 方法,构建过程生成的WAR文件仍可直接运行,一如可执行的JAR文件:

    $ java -jar readinglist-0.0.1-SNAPSHOT.war
    

    这样一来,同一个部署产物就能有两种部署方式了!

你可能感兴趣的:(部署Spring-boot)