Quarkus入门体验,22ms启动一个Web服务

简介

Quarkus是类似于Spring Boot的框架,可以方便大家进行Java开发。利用GraalVM的魔力,能更好的适应云原生的场景,极快的启动速度。

创建项目

在IDEA就直接有创建Quarkus项目的初始化工具,直接根据自己需要填好即可,非常方便:

选择自己需要的一些组件和依赖,我这里只选择Web Reactive。这跟Spring Boot挺像的。

生成的Java代码就一个文件,很简单小巧:

编译运行

创建成功后,把编译目标改为11,因为我用的是JDK11。通过mvn clean package尝试打包,下载依赖包。编译成功后,IDEA支持直接跑Quarkus程序,如下:

启动成功如下:

Quarkus在首页提供了一些开发信息和工具,如下:

访问服务如下:

直接修改Java代码:

@GET
@Produces(MediaType.TEXT_PLAIN)
public String hello() {
  return "Hello from pkslow.com";
}

不用重启就可以生效:

在Docker上运行

打包成Native的Docker镜像,命令如下:

$ mvn clean package -Dnative -Dquarkus.native.container-build=true -Dquarkus.native.container-runtime=docker

第一次可能比较长时间,需要下载镜像。但这种打镜像的方法是把文件放在镜像外面。通过-v的方式来运行。

所以我们再通过下面命令来生成镜像:


$ docker build -f src/main/docker/Dockerfile.native -t pkslow/quarkus-quickstart .
Sending build context to Docker daemon  55.41MB
Step 1/7 : FROM registry.access.redhat.com/ubi8/ubi-minimal:8.6
8.6: Pulling from ubi8/ubi-minimal
a6577091999b: Pull complete 
Digest: sha256:33931dce809712888d1a8061bfa676963f517daca993984afed3251bc1fb5987
Status: Downloaded newer image for registry.access.redhat.com/ubi8/ubi-minimal:8.6
 ---> abb1ba1bceab
Step 2/7 : WORKDIR /work/
 ---> Running in b1f6c5c33919
Removing intermediate container b1f6c5c33919
 ---> 44961ddcb521
Step 3/7 : RUN chown 1001 /work     && chmod "g+rwX" /work     && chown 1001:root /work
 ---> Running in e1c1a83e964f
Removing intermediate container e1c1a83e964f
 ---> 225868ceda2c
Step 4/7 : COPY --chown=1001:root target/*-runner /work/application
 ---> 55b2bba61da1
Step 5/7 : EXPOSE 8080
 ---> Running in 9b90514423eb
Removing intermediate container 9b90514423eb
 ---> 00f981b47b0e
Step 6/7 : USER 1001
 ---> Running in bd5d1b723784
Removing intermediate container bd5d1b723784
 ---> 14d55159d2d9
Step 7/7 : CMD ["./application", "-Dquarkus.http.host=0.0.0.0"]
 ---> Running in c60a96727644
Removing intermediate container c60a96727644
 ---> 77fdda464a6a
Successfully built 77fdda464a6a
Successfully tagged pkslow/quarkus-quickstart:latest

通过Docker来启动:

$ docker run -i --rm -p 8080:8080 pkslow/quarkus-quickstart
__  ____  __  _____   ___  __ ____  ______ 
 --/ __ \/ / / / _ | / _ \/ //_/ / / / __/ 
 -/ /_/ / /_/ / __ |/ , _/ ,< / /_/ /\ \   
--\___\_\____/_/ |_/_/|_/_/|_|\____/___/   
2022-11-01 07:36:38,557 INFO  [io.quarkus] (main) quarkus-quickstart 1.0-SNAPSHOT native (powered by Quarkus 2.13.3.Final) started in 0.022s. Listening on: http://0.0.0.0:8080
2022-11-01 07:36:38,558 INFO  [io.quarkus] (main) Profile prod activated. 
2022-11-01 07:36:38,558 INFO  [io.quarkus] (main) Installed features: [cdi, resteasy-reactive, smallrye-context-propagation, vertx]

可以看出启动相当快,才用了22ms。访问对应的网页和接口也是正常的。

代码

代码请看GitHub: https://github.com/LarryDpk/pkslow-samples


References:

CREATING YOUR FIRST APPLICATION

BUILDING A NATIVE EXECUTABLE

好的,针对您的问题,我可以提供一个简单的示例代码来说明如何在 Quarkus 中使用 Hibernate 执行查询时增加一个固定条件。 首先,您需要在您的 Quarkus 项目中添加 Hibernate 和相关依赖。然后,您可以创建一个 DAO 类,使用 Hibernate 来执行查询。在该 DAO 类中,您可以使用 Hibernate Criteria API 来构建查询条件,然后将其与您的固定条件组合起来。 以下是一个简单的示例代码,其中包含一个 DAO 类,该类使用 Hibernate 来查询一个名为 "Customer" 的实体,并将一个固定条件与查询条件组合在一起。 ``` import javax.enterprise.context.ApplicationScoped; import javax.inject.Inject; import javax.persistence.EntityManager; import javax.persistence.criteria.CriteriaBuilder; import javax.persistence.criteria.CriteriaQuery; import javax.persistence.criteria.Predicate; import javax.persistence.criteria.Root; import org.hibernate.Session; import org.hibernate.query.Query; import io.quarkus.hibernate.orm.panache.PanacheRepository; @ApplicationScoped public class CustomerRepository implements PanacheRepository<Customer> { @Inject EntityManager entityManager; public List<Customer> findCustomersWithFixedCondition(String fixedCondition) { Session session = entityManager.unwrap(Session.class); CriteriaBuilder builder = session.getCriteriaBuilder(); CriteriaQuery<Customer> criteriaQuery = builder.createQuery(Customer.class); Root<Customer> root = criteriaQuery.from(Customer.class); // 添加固定条件 Predicate fixedPredicate = builder.like(root.get("name"), fixedCondition); // 添加查询条件 Predicate queryPredicate = builder.and( builder.equal(root.get("isActive"), true), builder.equal(root.get("age"), 30) ); criteriaQuery.where(builder.and(fixedPredicate, queryPredicate)); Query<Customer> query = session.createQuery(criteriaQuery); return query.list(); } } ``` 在这个示例中,我们首先使用 EntityManager 来获取一个 Hibernate Session 对象,然后使用 CriteriaBuilder 来构建查询条件。我们添加了一个名为 "fixedCondition" 的固定条件,它与名为 "name" 的实体属性匹配。我们还添加了一些查询条件,例如 "isActive" 和 "age" 等属性。最后,我们将固定条件和查询条件组合起来,执行查询并返回结果。 希望这个示例代码能够帮助您解决问题。如果您有任何其他问题或需要进一步的帮助,请随时问我。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值