点击围观!腾讯 TAPD 助力金融行业研发提效、敏捷转型最佳实践! 了解详情
写点什么

Quarkus:一个 Kubernetes 原生 Java 框架

  • 2019-03-29
  • 本文字数:1232 字

    阅读完需:约 4 分钟

Quarkus:一个Kubernetes原生Java框架

Red Hat 发布了 Quarkus,这是一个为 GraalVM 和 OpenJDK HotSpot 量身定制的 Kubernetes 原生 Java 框架。Quarkus 的目标是使 Java 成为 Kubernetes 和无服务器环境中的领先平台,为开发人员提供统一的反应式和命令式编程模型。


Quarkus 利用 Java 开发人员使用的一系列库,如 Eclipse MicroProfile 和 Vert.x,带来了一个全栈框架。Quarkus 依赖注入基于 CDI,允许开发人员使用 JPA/Hibernate、JAX-RS/RESTEasy 等。此外,Quarkus 还包含一个扩展框架,第三方框架作者可以利用该框架对其进行扩展;这个扩展框架同时还编译成了一个 GraalVM 原生二进制文件。


RedHat 表示,Quarkus 提供了可观的运行时效率,比如快速启动,支持在容器和 Kubernetes 上自动伸缩微服务,而低内存利用率有助于优化微服务体系结构部署中的容器密度。同时,它还提供了更小的应用程序和容器镜像空间占用。



(图片来自: https://quarkus.io/


按照设计,Quarkus 完美地引入了命令式和反应式模型,旨在让熟悉命令式模型但不想学习新范式的 Java 开发人员以及采用云原生/反应式模型方法的开发人员快速采用。


命令式风格:


@InjectSayService say;
@GET@Produces(MediaType.TEXT_PLAIN)public String hello() { return say.hello();}
复制代码


反应式风格:


@Inject @Stream("kafka")Publisher reactiveSay;
@GET@Produces(MediaType.SERVER_SENT_EVENTS)public Publisher stream() { return reactiveSay;}
复制代码


也可以使用 Quarkus 实现在无服务器环境中使用的函数,比如,下面是一个 AWS Lambda 的例子:


public class HelloLambda implements RequestHandler {
@Inject HelloGreeter greeter;
@Override public String handleRequest(HelloRequest request, Context context) { return greeter.greet(request.firstName, request.lastName); }}
复制代码


Quarkus 被设计成少配置或无配置,其工作方式很直观。为此,开发人员可以用以下工具构建一个新项目:



mvn io.quarkus:quarkus-maven-plugin:0.12.0:create \ -DprojectGroupId=my-groupId \ -DprojectArtifactId=my-artifactId \ -DprojectVersion=my-version \ -DclassName="org.my.group.MyResource"
复制代码


Quarkus 还提供了“在线编码(Live Coding)”功能,使开发人员避免了编写代码→编译→部署→刷新浏览器→重复的枯燥过程。运行 mvn compile quarkus:dev,Quarkus 将在开发模式下启动。当它接收到 HTTP 请求时,它将保存该请求并检查是否更改了任何应用程序源文件。如果有,它将透明地编译更改的文件,重新部署应用程序,然后将 HTTP 请求发送给重新部署的应用程序。


Quarkus 似乎至少是云时代一个有趣的替代方案。在这个时代,容器、Kubernetes、微服务、函数即服务(FaaS)和云原生应用程序正在提供更高级别的生产力和效率。


要了解关于 Quarkus 的更多细节,请访问 quarkus.io。想要开始使用 Quarkus 的开发人员可以查看入门指南或其他可用的指南。


查看英文原文:Quarkus, a Kubernetes Native Java Framework


2019-03-29 06:4021111
用户头像

发布了 594 篇内容, 共 293.2 次阅读, 收获喜欢 1380 次。

关注

评论

发布
暂无评论
发现更多内容

《分布式系统设计》(2) 关键概念和基本问题

陈皓07

真假敏捷教练

escray

面试 面经 4月日更

Rust从0到1-枚举-定义

rust 枚举 Option

区块链电子证照平台搭建,助推政务数字化发展

13828808769

电子存证 区块链+ #区块链#

SpringCloud(Netfix)-技术专题-服务注册与发现

洛神灬殇

SpringCloud

「MySQL」深入理解事务的来龙去脉

学Java关注我

Java 编程 架构 程序人生 软件架构

树莓派安装pytorch

IT蜗壳-Tango

4月日更

对混沌工程的五个常见误解

混沌工程实践

混沌工程 故障注入 误区 生产事故 监管合规

JVM-技术专题-MAT解析OOM问题

洛神灬殇

JVM

升级版数字人民币试点在深启动 这次有啥不一样?

CECBC

数字人民币

Linux 下的Zabbix Agent 安装

耳东@Erdong

Linux zabbix 4月日更

Python OpenCV 图像处理之图像直方图,取经之旅第 25 天

梦想橡皮擦

Python OpenCV 4月日更

智慧公安情指勤系统搭建,指挥调度平台解决方

13828808769

智慧公安

爽面数码打底浆说明书

C13713145387

爽面数码打底浆 哑面数码打底浆 数码打底浆

余额宝|三年开发|一二三四+HR面面经,已拿offer|

Java架构师迁哥

Coinbase上市在即,这里有你想知道的一切

CECBC

比特币

三分钟热度的你,不会得到你想要的结果

小天同学

坚持 日常感悟 4月日更 专心 个人思考

什么是跨职能合作的关键?

王辉

团队管理 技术管理 沟通

Spark的动态资源分配

小舰

Spark调优 4月日更

Linux grep 命令

一个大红包

4月日更

Java流(Stream)操作实例-筛选、映射、查找匹配

Java小咖秀

Java stream java8 日常开发

区块链商品防伪溯源平台搭建,实现数据信息安全共享

13828808769

区块链 商品溯源 #区块链#

无脑用 react 的 useCallback

sadhu

React Hooks 无脑 useCallback

防晒衣专用水性油墨说明书

C13713145387

防晒衣专用水性油墨 防水尼龙水性油墨

升级JDK到1.8笔记

风翱

jdk8 4月日更

InheritableThreadLocal源码解析,子线程如何获取父线程的本地变量?

徐同学呀

ThreadLocal Java源码

微服务中台技术解析之项目环境隔离

小江

kafka 架构 DevOps 后端

神秘又强大的@SpringBootApplication注解

vivo互联网技术

Java 后端 springboot 注解分析

《分布式系统设计》(1) 从程序思维到系统思维

陈皓07

Spring 类型转换

邱学喆

Converter spring类型转换 GenericConversionService GenericConverter ResolvableType

透气胶浆、无手感透气胶浆

C13713145387

透气胶浆 仿拔印浆 无手感透气浆

Quarkus:一个Kubernetes原生Java框架_语言 & 开发_Diogo Carleto_InfoQ精选文章