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-12-11 16:04:15

    CSS中的 “var()” 和 “:root”

    var() var()函数可以代替元素中任何属性中的值的任何部分。var()函数不能作为属性名、选择器或者其他除了属性值之外的值。(这样做通常会产生无效的语法或者一个没有关联到变量的值。)

  • 2019-12-11 16:18:51

    npm发布vue组件

    开发之前先看看官网的 开发规范 我们开发的之后期望的结果是支持 import、require 或者直接使用 script 标签的形式引入,就像这样

  • 2019-12-11 16:21:00

    .vue文件 加scoped 样式不起作用

    在vue组件中,为了使样式私有化(模块化),不对全局造成污染,在style标签上添加scoped属性,以表示它只属于当下的模块。但是要慎用,因为在我们需要修改公共组件(第三方库或者项目中定制的组件)的样式的时候,scoped会造成很多困难,组要增加额外的复杂度。

  • 2019-12-11 16:22:04

    Vue中的scoped和scoped穿透,scoped原理

    在Vue文件中的style标签上有一个特殊的属性,scoped。当一个style标签拥有scoped属性时候,它的css样式只能用于当前的Vue组件,可以使组件的样式不相互污染。如果一个项目的所有style标签都加上了scoped属性,相当于实现了样式的模块化。

  • 2019-12-12 14:19:32

    laravel自定义分页LengthAwarePaginator

    有时候我们使用larave提供的后台分页数据库查询,有时候限制太多,我们需要自己定制分页功能。 下面是我给大家一个例子,我们可以根据例子,制作自己的分页功能。