zoukankan      html  css  js  c++  java
  • 【IntelliJ IDEA】spring boot项目在idea实现自动部署

    转载参考自:https://www.cnblogs.com/winner-0715/p/6666579.html

    spring-boot-devtools是一个为开发者服务的一个模块,其中最重要的功能就是自动应用代码更改到最新的App上面去。
    原理是在发现代码有更改之后,重新启动应用,但是速度比手动停止后再启动更快。
    其深层原理是使用了两个ClassLoader,一个Classloader加载那些不会改变的类(第三方Jar包),另一个ClassLoader加载会更改的类,称为restart ClassLoader
    ,这样在有代码更改的时候,原来的restart ClassLoader被丢弃,重新创建一个restart ClassLoader,由于需要加载的类相比较少,所以实现了较快的重启时间。

    即devtools会监听classpath下的文件变动,并且会立即重启应用(发生在保存时机)

    一、开启idea自动make功能 

    1、CTRL + SHIFT + A --> 查找make project automatically --> 选中 

    2、CTRL + SHIFT + A --> 查找Registry --> 找到并勾选compiler.automake.allow.when.app.running 

    二.pom.xml文件配置spring boot热部署插件

    1、加maven依赖

    <!--spring boot热部署插件-->
            <dependency>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-devtools</artifactId>
                <optional>true</optional>
            </dependency>

    2、开启热部署

    <!--开启热部署-->
        <build>
            <plugins>
                <plugin>
                    <groupId>org.springframework.boot</groupId>
                    <artifactId>spring-boot-maven-plugin</artifactId>
                    <configuration>
                        <fork>true</fork><!--这个必须加上-->
                    </configuration>
                </plugin>
            </plugins>
        </build>

    三、Chrome禁用缓存 
    F12(或Ctrl+Shift+J或Ctrl+Shift+I)--> NetWork --> Disable Cache(while DevTools is open) 

     =====================================================================

    修改完成!可以随时修改随时看到效果了【更改完成需要重启IDEA】

    =====================================================================

    测试方法:
    1.修改类-->保存:应用会重启
    2.修改配置文件-->保存:应用会重启
    3.修改页面-->保存:应用会重启,页面会刷新(原理是将spring.thymeleaf.cache设为false)

    不能使用分析:
    1.对应的spring-boot版本是否正确,我这里使用的是1.5.3.RELEASE版本;
    2.是否加入plugin了,以及属性<fork>true</fork>
    3.Intellij IDEA是否开启了Make Project Automatically。
    4.如果设置SpringApplication.setRegisterShutdownHook(false),则自动重启将不起作用。

  • 相关阅读:
    C#操作OFFICE一(EXCEL)
    json的使用二(转)
    xpath简介(转载)
    使用LogParser分析IIS网站日志
    WCF Data Contract KnownTypeAttribute转载
    ExtJs中同一个URL构造多个Ext.data.JsonStore 转载
    转载Ext.form.formPanel 与服务器交互 初始化表单
    oracle表数据误删恢复
    JavaScript基础之Array函数
    Json格式类的转换相关代码转载
  • 原文地址:https://www.cnblogs.com/sxdcgaq8080/p/7839114.html
Copyright © 2011-2022 走看看