,由于运行上千个应用程序容器荚Pod所耗费的资源多,令它实现较少工作节点和资源占用所需成本也较高,所以在使用 Kubernetes 时,快速启动和较少的内存占用是至关重要的。在 Kubernetes 平台运行容器化微服务时,内存占用是比吞吐量更重要的考量因素,这是因为:,这些情况极大影响了无服务器函数的发展和 Java 部署模型。到目前为止,许多企业开发人员选择 Go、Python 或 Node.js 这些替代方案来解决性能瓶颈,直到出现了 Quarkus 这种基于 kubernetes 的原生 Java 堆栈,才有所改观。本文介绍如何在使用了 Quarkus 的 kubernetes 平台上进行性能优化,以便运行无服务器函数。,由于 Java 生态系统中传统的框架都要进行框架的初始化,包括配置文件的处理、classpath 的扫描、类加载、注解的处理以及构建元模型,这些过程都是必不可少的,所以它们都比较耗费资源。如果使用了几种不同的框架,所耗费的资源也是成倍增加。,Quarkus 通过“左移shifting left”,把所有的资源开销大的操作都转移到构建阶段,解决了这些 Java 性能问题。在构建阶段进行代码和框架分析、字节码转换和动态元模型生成,而且只有一次,结果是:运行时可执行文件经过高度优化,启动非常快,不需要经过那些传统的启动过程,全过程只在构建阶段执行一次。,
,Quarkus Build phase,更重要的是:Quarkus 支持构建原生可执行文件,它具有良好性能,包括快速启动和极小的驻留集大小resident set size(RSS)内存占用,跟传统的云原生 Java 栈相比,具备即时扩展的能力和高密度的内存利用。,
,Quarkus RSS and Boot Time Metrics,这里有个例子,展示如何使用 Quarkus 将一个 Java 无服务器 项目构建为本地可执行文件。,以下命令生成一个 Quarkus 项目,(例如 quarkus-serverless-native)以此创建一个简单的函数:,你需要使用 GraalVM 为 Java 程序构建一个本地可执行文件。你可以选择 GraalVM 的任何发行版,例如 Oracle GraalVM Community Edition (CE) 或 Mandrel(Oracle GraalVM CE 的下游发行版)。Mandrel 是为支持 OpenJDK 11 上的 Quarkus-native 可执行文件的构建而设计的。,打开 pom.xml,你将发现其中的 native 设置。你将使用它来构建本地可执行文件。,假设你已经打开了容器运行时,此时需要运行一下 Maven 命令:,使用 Docker 作为容器引擎:,使用 Podman 作为容器引擎:,输出信息结尾应当是 BUILD SUCCESS。,
,Native Build Logs,不借助 JVM 直接运行本地可执行文件:,输出信息类似于:,简直是超音速!启动只花了 19 毫秒。你的运行时间可能稍有不同。,使用 Linux 的 ps 工具检测一下,结果内存占用还是很低。检测的方法是:在应用程序运行期间,另外打开一个终端,运行如下命令:,输出结果类似于:,该进程只占 11MB 内存。非常小!,你也可以使用 REST API 访问这个函数。输出结果应该是 Hello RESTEasy:,如果你还没有创建命名空间,现在就在 OKD(OpenShift Kubernetes 发行版)创建一个命名空间(例如 quarkus-serverless-native),进而把这个本地可执行文件部署为无服务器函数。然后添加 quarkus-openshift 扩展:,向 src/main/resources/application.properties 文件中添加以下内容,配置 Knative 和 Kubernetes 的相关资源:,构建本地可执行文件,并把它直接部署到 OKD 集群:,输出信息结尾应当是 BUILD SUCCESS。完成一个本地二进制文件的构建并部署为 Knative 服务需要花费几分钟。成功创建服务后,使用 kubectl 或 oc 命令工具,可以查看 Knative 服务和版本信息:,运行 kubectl 命令,搜索无服务器函数的节点:,输出信息类似于:,用 curl 命令访问上述信息中的 URL 字段:,过了不超过一秒钟,你也会得到跟本地操作一样的结果:,当你在 OKD 群集中访问 Quarkus 运行中的节点的日志,你会发现本地可执行文件正在以 Knative 服务的形式运行。,
,Native Quarkus Log,你可以借助 GraalVM 发行版优化 Java 无服务器函数,从而在 Knative 中使用 Kubernetes 将它们部署为无服务器函数。Quarkus 支持在普通的微服务中使用简易配置进行性能优化。,本系列的下一篇文章将指导你在不更改代码的情况下跨多个无服务器平台实现可移植函数。,(Daniel Oh, CC BY-SA 4.0)
© 版权声明
文章版权归作者所有,未经允许请勿转载。