SrpingBoot 热启动与热部署

2019-09-09 05:32:55

代码热部署


当我们已经启动了一个服务,然后修改代码之后,会自动重新部署。Spring项目通常有新内容修改后需要重新编译然后运行。通过配置Spring boot的热启动配置,可以实现自动编译重启项目,通常要比手动停止,启动项目快。


1、引入spring-boot-devtools

pom中添加响应的jar包及插件


    <!-- 热启动,热部署依赖包 -->

            <dependency>

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

                <artifactId>spring-boot-devtools</artifactId>

                <optional>true</optional>

            </dependency>

1

2

3

4

5

6

2、引入对应的插件


<!-- 热启动,热部署依赖插件 -->

            <plugin>

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

                <artifactId>spring-boot-maven-plugin</artifactId>

                <configuration>

                    <fork>true</fork>

                </configuration>

            </plugin>

1

2

3

4

5

6

7

8

通过上面的2步,就可以实现代码的热部署了。

IDEA中 修改代码后需要通过 Ctrl+F9 重新编译


原理介绍


    spring-boot-devtools 是一个为开发者服务的一个模块,其中最重要的功能就是自动应用代码更改到最新的App上面去。

    原理是在发现代码有更改之后,重新启动应用,但是速度比手动停止后再启动还要更快,

    更快指的不是节省出来的手工操作的时间。

1

2

3

其深层原理是:


    使用了两个ClassLoader,一个Classloader加载那些不会改变的类(第三方Jar包),

    另一个ClassLoader加载会更改的类,称为 restart ClassLoader,

    这样在有代码更改的时候,原来的restart ClassLoader 被丢弃,

    重新创建一个restart ClassLoader,由于需要加载的类相比较少,

    所以实现了较快的重启时间(5秒以内)。

1

2

3

4

5

部署方式:

热部署 :在服务器运行时重新部署项目,直接重新加载整个应用,更多是在生产环境使用

热加载:在运行时重新加载class,更多是在开发环境使用


热部署



                <dependencies>

                    <dependency>

                        <groupId>org.springframework</groupId>

                        <artifactId>springloaded</artifactId>

                        <version>1.2.8.RELEASE</version>

                    </dependency>

                </dependencies>

1

2

3

4

5

6

7

mvn spring-boot:run


以上是spring boot 热部署的方式之一。

还有2种方式,一种是通过下载springbootloaded jar包,在vm中启动

另外一种 比较复杂可以通过加参数完成启动。


  1. 然后使用快捷键“Ctrl+Shift+A”,搜索“Registry”,如图所示。

    IntelliJ IDEA怎么热启动springboot项目

  2. 然后把如图所示的key进行勾选就可以了,如图所示。

    IntelliJ IDEA怎么热启动springboot项目



  • 2019-10-19 16:35:45

    Vue.directive使用注意

    首先,Vue.directive要在实例初始化之前,不然会报错,还有,定义的指令不支持驼峰式写法,也会报下面同样的错,虽然在源码中没有找到在哪里统一处理大小写,但是在有关directive的方法中捕捉到的指令命名统一变为小写,所以,还是用'-'或者'_'分割吧。

  • 2019-10-21 08:39:54

    vue slot用法以及使用介绍

    通过上面的内容可以知道,在slot组件中引入了slot的子组件,而且又在子组件标签内添加了新的标签内容,但页面上并没有将子组件标签内的标签内容显示出来,

  • 2019-10-21 15:06:27

    yarn详细入门教程

    Yarn 是 Facebook, Google, Exponent 和 Tilde 开发的一款新的 JavaScript 包管理工具。就像我们可以从官方文档了解那样,它的目的是解决这些团队使用 npm 面临的少数问题,即:

  • 2019-10-23 10:20:48

    php 去掉 头尾 空格 2种方法

    看似很简单的问题,其实还是有点坑的,首先这里&nbsp;空格转义,不是字符串,直接用trim()是去不掉。

  • 2019-10-23 23:25:22

    PostMapping,GetMapping不固定路径的写法

    PostMapping中的value属性是数组,所以可以定义多个路径,required属性默认是true,不必再写required=true,默认表示该参数是必须要有的,如果写required=false,表示该参数是可选的,可有可无。

  • 2019-10-24 01:14:29

    通过属性搜索商品mysql设计

    属性是可以动态扩展的,问题:属性是搜索条件 问:请展示出 材质为塑料 防水为YES,颜色为绿色的商品详细信息,按照sort_filed排序

  • 2019-10-25 15:18:18

    Vue.use Vue.prototype区别

    1、不是为了vue写的插件(插件内要处理)不支持Vue.use()加载方式 2、非vue官方库不支持new Vue()方式 3、每一个vue组件都是Vue的实例,所以组件内this可以拿到Vue.prototype上添加的属性和方法。

  • 2019-10-25 23:33:45

    php制作漂亮的随机颜色标签云效果

    代码中的array里面的字符串就是各种随机色的编码,大家可以根据自己的需求来配置颜色。 然后input1里面是字体大小的随机代码,也可以自行修改。