quarkus实战之三:开发模式(Development mode)

x33g5p2x  于2022-03-05 转载在 其他  
字(2.8k)|赞(0)|评价(0)|浏览(407)

欢迎访问我的GitHub

这里分类和汇总了欣宸的全部原创(含配套源码):https://github.com/zq2599/blog_demos

本篇概览

  • 前文咱们曾提到过几种启动方式,有一种用maven命令启动的,可以进入开发模式,命令如下:
mvn quarkus:dev
  • 当时只提到此模式能看到详细系统信息,并未展开说明更多信息,实际上,此模式下还有很多实用的功能
  • 作为《quarkus实战》系列的第三篇,今天咱们一起来学习开发模式(Development mode),这是quarkus为开发者准备的实用工具

关于开发模式(Development mode)

  • 开发模式是quarkus框架提供的内置工具(built-in),可直接使用
  • 开发模式提供以下功能:
  1. 系统信息:即前文提到过的,查看对象和配置、修改配置、操作单元测试等功能
  2. 热部署:修改java代码、资源文件、配置文件等类型的文件后,会立即生效
  3. 断点:这是常用功能就不多说了,稍后直接操作
  • 接下来实际体验上述功能,用的是《quarkus实战之二:体验HelloWorld》一文中创建的demo工程

系统信息

  • 访问http://localhost:8080/q/dev/,可以看到丰富的系统信息,该地址只在dev模式有效:

热部署

  • 热部署是日常开发的常用功能,回顾demo中的HobbyResource.java,如下所示,非常简单:
package com.bolingcavalry;

import javax.ws.rs.GET;
import javax.ws.rs.Path;
import javax.ws.rs.Produces;
import javax.ws.rs.core.MediaType;
import java.time.LocalDateTime;

@Path("/actions")
public class HobbyResource {

    @GET
    @Produces(MediaType.TEXT_PLAIN)
    public String hello() {
        return "Hello RESTEasy " + LocalDateTime.now();
    }
}
  • 为了演示修改配置可以立即生效的效果,把代码改成下面这样,注意注解ConfigProperty的作用是将指定配置的值注入修饰的成员变量中:
package com.bolingcavalry;

import org.eclipse.microprofile.config.inject.ConfigProperty;
import javax.ws.rs.GET;
import javax.ws.rs.Path;
import javax.ws.rs.Produces;
import javax.ws.rs.core.MediaType;
import java.time.LocalDateTime;

@Path("/actions")
public class HobbyResource {

    @ConfigProperty(name = "greeting.message")
    String message;

    @GET
    @Produces(MediaType.TEXT_PLAIN)
    public String hello() {
        return "Hello RESTEasy " + LocalDateTime.now() + " " + message;
    }
}
  • 打开文件application.properties,增加一个配置:
# 这是一个自定义属性
greeting.message=message from configuration
  • 用命令mvn quarkus:dev将应用以开发模式启动,用浏览器访问http://localhost:8080/actions,响应如下图,符合预期,配置的属性可以被正常使用:

  • 现在去修改代码,如下图红框:

  • 再把文件application.properties中的配置也改了,我这里改成了abcdef
  • 再去刷新页面,如下图所示,代码和配置的修改都生效了:

  • 以上就是热部署了,接下来去看另一个实用的功能:断点

断点

  • 打断点、单步调试等都是Java程序员的日常操作,就不做介绍了,直接聊聊quarkus上如何操作吧
  • 在开发模式下,断点功能是默认开启的,不过为了安全起见,quarkus断点只监听了localhost网卡,端口是5005
  • 在代码中打个断点,如下图,我这里用的是IDEA:

  • 在IDEA上新增一个断点,操作如下图:

  • 如下图所示,确认端口号正确:

  • 配置完成后,点击下图红框中的按钮即可发起断点请求:

  • 如果应用正常监听,应该能立即连接成功,如下图:

  • 刷新浏览器,请求会立即停留在断点位置,一切都是熟悉的样子,可以像以前一样查看变量和堆栈,也可以做单步执行和条件断点等操作:

  • 以上是通过localhost:5005进行本地调试的操作步骤,如果另外一台电脑想连接到到这个quarkus应用进行远程调式,是连接不成功的,因为quarkus应用启动后监听的是localhost这块网卡,为了能够让其他电脑上的IDEA远程连接到这个应用,我们需要给启动命令增加一个参数,令其监听本机所有网卡,支持远程debug的完整启动命令如下,另外,debug参数可以指定端口:
mvn quarkus:dev -DdebugHost=0.0.0.0 -Ddebug=5006
  • 启动后控制台输出信息如下图,红框中显示监听的端口是5006

  • 当前电脑的IP是192.168.50.221,所以将断点的地址从localhost:5005改为192.168.50.221:5006,如下图:

  • 再尝试连接断点,如下所示,新的IP+端口连接成功:

  • 因为连接是基于IP+端口的,您完全可以在A电脑上运行应用,在B电脑上用IDEA远程连接A电脑进行断点操作

热部署的局限性

  • 前面的操作:在A电脑用mvn quarkus:dev -DdebugHost=0.0.0.0 -Ddebug=5006命令启动应用,在B电脑上用IDEA连接到A电脑上进行热部署操作,虽然也算是远程,但聪明的您应该看出了弊端:A电脑上必须有源码
  • 很多时候,我们热部署是为了处理特定问题,而出现问题的电脑可能是测试环境,甚至生产环境,这些地方是不会有源码和maven的,此时mvn quarkus:dev命令就行不通了,那又该如何处理呢?放弃热部署的便利,只能改一次代码部署一次吗?
  • 好在quarkus已经考虑到这种情况,为我们准备了远程热部署方案,下一篇文章会详细介绍和操作

你不孤单,欣宸原创一路相伴

  1. Java系列
  2. Spring系列
  3. Docker系列
  4. kubernetes系列
  5. 数据库+中间件系列
  6. DevOps系列

相关文章