Quarkus初探

Quarkus初探

  • 背景
  • 安装Quarkus
    • 安装Quarkus CLI
  • 创建Quarkus项目
    • 运行Quarkus
    • 初探代码
      • 修改一下代码
    • 数据持久化
      • 创建PanacheEntiry
      • 写入数据
      • 读取数据
    • Dev Service
      • 使用外部数据库
      • 区分dev和prod
    • 构建native应用(依赖Graalvm)

背景

最早是在Infoq上了解到Quarkus这个框架,内部集成了Vertx,对native-image有着非常好的支持,启动速度非常快,占用内存很小(相较于Springboot),最近有时间就来体验一下。

安装Quarkus

Quarkus也是基于Java的微服务框架,所以想要体验Quarkus需要满足以下条件:

  1. JDK 17+,配置配置好了JAVA_HOME
  2. Apache Maven 3.9.6
  3. docker或podman(可选)
  4. Quarkus CLI(可选)
  5. Graalvm(可选,用于构建Native应用)

安装Quarkus CLI

Quarkus CLI中提供了很多命令,可以帮助我们快速的创建、运行Quarkus项目。这两天体验下来Quarkus CLI应该是主要对mvn的各类命令进行了集成,Quarkus CLI的命令相较于mvn来说更加便捷,也是推荐大家安装体验一下。目前官方支持以下几种安装方式:

  • JBang - for Linux, macOS and Windows
  • SDKMAN! - for Linux and macOS
  • Homebrew - for Linux and macOS
  • Chocolatey - for Windows
  • Scoop - for Windows

我目前这台机器是通过SDKMAN来管理JDK版本的,这里选择了使用SDKMAN进行安装

sdk install quarkus

安装完成之后验证一下

quarkus --version
3.9.2

创建Quarkus项目

通过quarkus执行以下命令

quarkus create app org.acme:getting-started-dev-services \--extension='rest'
cd getting-started-dev-services

或者通过maven

mvn io.quarkus.platform:quarkus-maven-plugin:3.9.2:create \-DprojectGroupId=org.acme \-DprojectArtifactId=getting-started-dev-services \-Dextensions='rest'
cd getting-started-dev-services

如果想要创建一个gradle项目,可以追加以下参数 -DbuildTool=gradle 或 -DbuildTool=gradle-kotlin-dsl

对于使用windows的同学,有以下两点需要注意:

  • 如果使用cmd,不要使用\分割命令,所有命令都要放在同一行中
  • 如果使用PowerShell,-D的参数需要使用双引号括起来,e.g."-DprojectArtifactId=getting-started-dev-services"

运行Quarkus

quarkus devor
./mvnw quarkus:devor
./gradlew --console=plain quarkusDev

正常启动后可以看到如下信息:

__  ____  __  _____   ___  __ ____  ______ --/ __ \/ / / / _ | / _ \/ //_/ / / / __/ -/ /_/ / /_/ / __ |/ , _/ ,< / /_/ /\ \   
--\___\_\____/_/ |_/_/|_/_/|_|\____/___/   
2024-04-10 11:22:05,350 INFO  [io.quarkus] (Quarkus Main Thread) code-with-quarkus 1.0.0-SNAPSHOT on JVM (powered by Quarkus 3.9.2) started in 0.842s. Listening on: http://localhost:80802024-04-10 11:22:05,351 INFO  [io.quarkus] (Quarkus Main Thread) Profile dev activated. Live Coding activated.

然后我们在浏览器里访问 http://localhost:8080/hello,应该可以看到如下信息

Hello from Quarkus REST

初探代码

我们使用IDE打开刚刚创建的项目,可以看到只有一个很简单的类GreetingResource

package org.acme;import jakarta.ws.rs.GET;
import jakarta.ws.rs.Path;
import jakarta.ws.rs.Produces;
import jakarta.ws.rs.core.MediaType;@Path("/hello")
public class GreetingResource {@GET@Produces(MediaType.TEXT_PLAIN)public String hello() {return "Hello from Quarkus REST";}
}

相交于Springboot来说,这里不需要定义一个Application启动类,再增加一个Controller,一个简简单单的GreetingResource就完成了所有的功能,这里使用到的注解也都是jakarta的标准注解。

修改一下代码

public String hello(@RestQuery String name) {return "Hello " + name;
}

然后我们访问http://localhost:8080/hello?name=Bloom
这时我们会看到这样一条消息: Hello Bloom.
quarkus dev模式支持代码热部署,在我们修改代码之后无需重启,调试修改的时候会非常方便。

对应的我们修改一下单元测试 src/test/java/org/acme/GreetingResourceTest.java,将

.body(is(“Hello from Quarkus REST”));

修改为

.body(containsString(“Hello”));

不然下次启动会报错(quarkus默认启动时会先执行单元测试)

数据持久化

在进行这一步之前,建议把我们本地的容器服务启动(docker或podman)起来,看看接下来会发生什么

创建PanacheEntiry

quarkus extension add hibernate-orm-panache jdbc-postgresql
或者
./mvnw quarkus:add-extension -Dextensions=‘hibernate-orm-panache jdbc-postgresql’

官方示例提供的是postgresql,你也可以替换为mysql。
创建一个Greeting.java

import io.quarkus.hibernate.orm.panache.PanacheEntity;
import jakarta.persistence.Entity;@Entity
public class Greeting extends PanacheEntity {public String name;
}

Panache是一个基于Hibernate的orm框架,PanacheEntity(类似于Spring-Data中的JpaRepository)中提供了大量的方法方便我们进行CRUD的操作

写入数据

@GET
@Transactional
@Produces(MediaType.TEXT_PLAIN)
public String hello(@QueryParam("name") String name) {Greeting greeting = new Greeting();greeting.name = name;greeting.persist();return "Hello " + name;
}

这里只是一个示例,在正式的代码中,GET请求不应该向后端服务写入数据

读取数据

@GET
@Path("names")
@Produces(MediaType.TEXT_PLAIN)
public String names() {List<Greeting> greetings = Greeting.listAll();String names = greetings.stream().map(g-> g.name).collect(Collectors.joining (", "));return "I've said hello to " + names;
}

来试一下效果, 先访问 http://localhost:8080/hello?name=Bloom, 再访问 http://localhost:8080/hello/names.

我们就能看到: “I’ve said hello to Bloom”.

Dev Service

进行到这里,你肯定会有很多疑问,我本地都没有PG数据库,项目中也没有任何数据库相关的配置,为什么没有报错?这一切都是怎么发生的?
这时你可以打开自己的Docker desktop或者使用docker ps的命令,你就会发现有一个PG的数据库实例正在运行

% docker ps
CONTAINER ID   IMAGE                       COMMAND                   CREATED              STATUS              PORTS                     NAMES
38c07eab6549   postgres:14                 "docker-entrypoint.s…"   About a minute ago   Up About a minute   0.0.0.0:61089->5432/tcp   kind_yalow

这一切都是Dev Service为我们做的,由于我们添加了jdbc-postgresql的依赖,Dev Service就为我们启动了一个postgresql的容器,方便我们更加快速的进行项目搭建。

另外,在dev模式下,处于Dev Services管理的数据库,Quarkus会使用drop-and-create的模式,所以我们每次修改代码重启服务之后,之前保存的数据都会丢失。在某些情况下,这种模式会很不方便,Quarkus也提供了一种机制来进行数据的初始化
我们可以创建一个sql文件src/main/resources/import.sql

INSERT INTO Greeting(id, name)
VALUES (nextval('Greeting_SEQ'), 'Alice');
INSERT INTO Greeting(id, name)
VALUES (nextval('Greeting_SEQ'), 'Bob');

这样每次quarkus启动时都会将这些数据初始化进去

使用外部数据库

如果我们已经搭建好了一个数据库,我们可以在src/main/resources/application.properties中增加如下配置

# configure your datasource
quarkus.datasource.db-kind = postgresql
quarkus.datasource.username = leopold
quarkus.datasource.password = bloom
quarkus.datasource.jdbc.url = jdbc:postgresql://localhost:5432/mydatabase

区分dev和prod

如果你想在开发和测试环境中使用Dev Service,在生产环境使用外包数据库,可以通过一个%prod的前缀来区分

# configure your datasource
%prod.quarkus.datasource.db-kind = postgresql
%prod.quarkus.datasource.username = leopold
%prod.quarkus.datasource.password = bloom
%prod.quarkus.datasource.jdbc.url = jdbc:postgresql://localhost:5432/mydatabase

构建native应用(依赖Graalvm)

Quarkus一大亮点是对native-image有着非常好的支持,想要体验native-image需要先安装Graalvm,你可以通过官网或者SDKMAN进行安装和配置。

quarkus build --native
./mvnw install -Dnative

编译的过程会比较长,编译完成之后会在target文件夹下生成一个getting-started-dev-services-1.0.0-SNAPSHOT-runner的可执行文件,可以直接启动。

需要注意的是,通过native构建出来的可执行程序会失去跨平台的特性,因此在一个平台上构建出来的native-image往往无法在其他平台运行,最好的方式是通过docker等容器进行部署。

目前Graalvm有一个实验性的功能,在Linux平台来构建跨平台的应用,具体可以参考
https://www.graalvm.org/jdk21/reference-manual/native-image/guides/build-static-executables/#prerequisites-and-preparation

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/807657.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

PKI:构建数字安全基石的关键技术

在数字化时代&#xff0c;网络安全已成为我们日常生活和工作的重要组成部分。为了确保数据的完整性、机密性和身份的真实性&#xff0c;公钥基础设施&#xff08;Public Key Infrastructure&#xff0c;简称PKI&#xff09;技术应运而生&#xff0c;为构建数字安全基石提供了重…

蓝桥杯JAVA组备赛模板1:快速幂

快速幂&#xff1a; static long gcd(long a, long b) {return b 0 ? a : gcd(b, a % b);}static long lcm(long a, long b) {return (a / gcd(a, b)) * b;}//快速幂static long powl(long a, int b) {if (a 0)return 0;long ans 1;while (b > 0) {if ((b & 1) >…

C++11 设计模式0. 设计模式的基本概念,设计模式的准则,如何学习设计模式,24种设计模式的分为3大类

一 设计模式的基本概念&#xff1a; 模式&#xff1a;指事物的标准样式 或者 理解成 针对特定问题的可重用解决方案。 设计模式&#xff0c;是在特定问题发生时的可重用解决方案。 设计模式一般用于大型项目中。 大型项目中&#xff0c;设计模式保证所设计的模块之间代码的灵…

【软考---系统架构设计师】计算机网络章节

目录 一、TCP/IP协议族 &#xff08;1&#xff09;基本介绍 &#xff08;2&#xff09;TCP和UDP的区别 &#xff08;3&#xff09;DNS协议 &#xff08;4&#xff09;DHCP协议 二、网络规划与设计 &#xff08;1&#xff09;需求分析 &#xff08;2&#xff09;通信规范…

K8S问题记录

服务器宕机导致K8S集群异常&#xff0c;部分nginx服务的pod启动失败 K8S版本&#xff1a;v1.12.5 问题1 nginx pod 启动失败&#xff0c;故障现象如下 nginx Pod 启动以后马上报错&#xff1a; [rootjd-training-cpu-01 ~]# kubectl logs -n paisystem easydl-fe-nginx-79b…

Jenkins构建时报错Error: EACCES: permission denied, open ‘/root/.npmrc解决

在使用Jenkins进行自动化构建时&#xff0c;你可能会遇到权限问题&#xff0c;如“Error: EACCES: permission denied, open ‘/root/.npmrc’”。这类问题通常与文件访问权限有关。本文将详细介绍如何识别和解决这些权限问题&#xff0c;确保你的自动化构建过程顺畅无阻。 问…

VUE3的有关知识

学习vue3的原因 在vue2当中的组件的实例,都是data一块,computed一块,当我们去找某一变量相关的则十分麻烦,vue3是组合式API,vue2是选项式, vue3的优点: 1)组合式更易维护 2)更快的速度 3)更小的体积 4)更好的响应式proxy 使用vue3相关脚手架创建项目 步骤: 1)node -v node版…

Linux查看系统配置信息的命令【lscpu】【free】【df】【uname】【lsblk】【top】

目录 1.查看CPU信息【lscpu】 2.查看内存信息【free】 3.查看文件系统信息【df】 4.查看系统信息【uname】 知识扩展&#xff1a;Red Hat Enterprise Linux 和 Debian GNU/Linux 两者的发展介绍 知识扩展&#xff1a;Centos 和 ubuntu的区别 知识扩展&#xff1a;更多 …

【简单讲解下Tauri】

&#x1f308;个人主页:程序员不想敲代码啊 &#x1f3c6;CSDN优质创作者&#xff0c;CSDN实力新星&#xff0c;CSDN博客专家 &#x1f44d;点赞⭐评论⭐收藏 &#x1f91d;希望本文对您有所裨益&#xff0c;如有不足之处&#xff0c;欢迎在评论区提出指正&#xff0c;让我们共…

“JavaScript数组:使用与实践“

目录 引言 1. 数组简介 2. 数组方法API 添加和删除元素 修改和访问元素 数组遍历 数组转换和连接 数组排序和搜索 其他常用方法 3. 数组属性 4. 实现数组API 实现添加和删除元素的方法 实现修改和访问元素的方法 实现数组遍历的方法 实现数组转换和连接的方法 …

【Python】FANUC机器人OPC UA通信并记录数据

目录 引言机器人仿真环境准备代码实现1. 导入库2. 设置参数3. 日志配置4. OPC UA通信5. 备份旧CSV文件6. 主函数 总结 引言 OPC UA&#xff08;Open Platform Communications Unified Architecture&#xff09;是一种跨平台的、开放的数据交换标准&#xff0c;常用于工业自动化…

聊聊Redis消息队列stream

前言 本期和大家一起探讨了如何基于 redis 实现消息队列&#xff0c;其中实现方案包括三类&#xff1a; redis list&#xff1a;最简单粗暴的实现&#xff0c;存在问题包括&#xff1a;不支持发布/订阅模式、消费端缺少 ack 机制redis pub/sub&#xff1a;支持发布/订阅模式&…

无“相关性”是指商品与分享内容无相关性,下列哪个行为不属于(无)相关性”违规?()

需要查看更多试题和答案&#xff0c;可以前往&#xff08;题海舟试题答案&#xff09;进行搜题查看。可以搜“题干关键词”。 无“相关性”是指商品与分享内容无相关性&#xff0c;下列哪个行为不属于(无)相关性”违规?() A.篮球比赛直播&#xff0c;售卖球衣、球鞋、球类与球…

从挑战到机遇:HubSpot如何帮助企业化解出海过程中的难题

企业出海挑战与对策 随着全球化的加速推进&#xff0c;越来越多的企业开始将目光投向海外市场&#xff0c;以寻求更广阔的发展空间。然而&#xff0c;在出海的过程中&#xff0c;企业往往面临着诸多挑战&#xff0c;其中文化差异、法律限制等问题尤为突出。今天运营坛将对这些…

快速开始vue3

版本 node (20.11.1)vue3 (3.4.21)脚手架创建项目并运行 安装脚手架并创建项目npm create vue@latest这一指令将会安装并执行 create-vue,它是 Vue 官方的项目脚手架工具 2) 安装以下进行选择 ## 配置项目名称 √ Project name: vue3_test ## 是否添加TypeScript支持 √ Add…

创意解决方案:如何将作品集视频集中于一个二维码或链接中?

引言&#xff1a;随着面试环节的进一步数字化&#xff0c;展示自己的作品集成为了求职过程中的重要一环。但除了使用传统的方式&#xff0c;如百度网盘或直接发送多个视频链接&#xff0c;有没有更便捷的方法将作品集的多个视频放在一个链接中呢? 本文将介绍一种创意解决方案…

如何使用try-with-resources关闭非自己创建的InputStream

如何使用try-with-resources关闭非自己创建的InputStream 在Java中&#xff0c;不论InputStream是自己创建的还是由外部提供的&#xff0c;只要它是AutoCloseable的实例&#xff0c;你都可以使用try-with-resources语句来确保它在不再需要时被自动关闭。 try-with-resources语…

RocketMQ 之 IoT 消息解析:物联网需要什么样的消息技术?

作者&#xff1a;林清山&#xff08;隆基&#xff09; 前言&#xff1a; 从初代开源消息队列崛起&#xff0c;到 PC 互联网、移动互联网爆发式发展&#xff0c;再到如今 IoT、云计算、云原生引领了新的技术趋势&#xff0c;消息中间件的发展已经走过了 30 多个年头。 目前&a…

数据库被rmallox勒索病毒加密,如何还原?

近年来&#xff0c;网络安全问题日益严峻&#xff0c;勒索病毒作为其中的一种恶意软件&#xff0c;已成为网络安全领域的一大难题。其中&#xff0c;rmallox勒索病毒以其高度的隐蔽性和破坏性&#xff0c;给不少企业和个人带来了严重损失。本文将从rmallox勒索病毒的特点、传播…

一个简单的UI自动化框架应用介绍

项目框架介绍 该数据自动校验小程序采用POM模型&#xff0c;基于Javaseleniumtestngextentsreportexcel POI开发。 框架核心功能 基于PMO模型将页面封装成java对象&#xff0c;并通过selenuim驱动浏览器进行操作。通过excel POI对excel文件进行操作&#xff0c;通过对比导出…