您当前的位置:首页 > 电脑百科 > 程序开发 > 容器

优化 Kubernetes 中的 Java 无服务器函数 | Linux 中国

时间:2022-10-26 14:52:53  来源:Linux中国  作者:

导读:在 Kube.NETes 中运行无服务器函数时,实现更快的启动速度和更小的内存占用。

本文字数:5814,阅读时长大约: 7分钟

由于运行上千个应用程序容器荚(Pod)所耗费的资源多,令它实现较少工作节点和资源占用所需成本也较高,所以在使用 opensource.com 时,快速启动和较少的内存占用是至关重要的。在 Kubernetes 平台运行容器化微服务时,内存占用是比吞吐量更重要的考量因素,这是因为:

◈ 由于需要持续运行,所以耗费资源更多(不同于 CPU 占用)

◈ 微服务令开销成本成倍增加

◈ 一个单体应用程序变为若干个微服务的情况(例如 20 个微服务占用的存储空间约有 20GB)

这些情况极大影响了无服务器函数的发展和 JAVA 部署模型。到目前为止,许多企业开发人员选择 Go、Python/ target=_blank class=infotextkey>Python 或 Node.js 这些替代方案来解决性能瓶颈,直到出现了 quarkus.io 这种基于 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 将一个 opensource.com 项目构建为本地可执行文件。

1、使用 Quarkus 创建无服务器 Maven 项目

以下命令生成一个 Quarkus 项目,(例如quarkus-serverless-native)以此创建一个简单的函数:

 

  1. $ mvn io.quarkus:quarkus-maven-plugin:1.13.4.Final:create

     

  2. -DprojectGroupId=org.acme

     

  3. -DprojectArtifactId=quarkus-serverless-native

     

  4. -DclassName="org.acme.getting.started.GreetingResource"

     

 

2、构建一个本地可执行文件

你需要使用 GraalVM 为 Java 程序构建一个本地可执行文件。你可以选择 GraalVM 的任何发行版,例如 www.graalvm.org 或 Github.com(Oracle GraalVM CE 的下游发行版)。Mandrel 是为支持 OpenJDK 11 上的 Quarkus-native 可执行文件的构建而设计的。

打开pom.xml,你将发现其中的native设置。你将使用它来构建本地可执行文件。

 

  1. native

  2. native
     

注意: 你可以在本地安装 GraalVM 或 Mandrel 发行版。你也可以下载 Mandrel 容器映像来构建它(像我那样),因此你还需要在本地运行一个容器引擎(例如 Docker)。

 

假设你已经打开了容器运行时,此时需要运行一下 Maven 命令:

使用 www.docker.com 作为容器引擎:

 

  1. $ ./mvnw package -Pnative

     

  2. -Dquarkus.native.contAIner-build=true

     

  3. -Dquarkus.native.container-runtime=docker

     

 

使用 podman.io 作为容器引擎:

 

  1. $ ./mvnw package -Pnative

     

  2. -Dquarkus.native.container-build=true

     

  3. -Dquarkus.native.container-runtime=podman

     

 

输出信息结尾应当是BUILD SUCCESS

Native Build Logs

不借助 JVM 直接运行本地可执行文件:

 

  1. $ target/quarkus-serverless-native-1.0.0-SNAPSHOT-runner

     

 

输出信息类似于:

 

  1. __ ____ __ _____ ___ __ ____ ______

     

  2. --/ __ / / / / _ | / _ / //_/ / / / __/

     

  3. -/ /_/ / /_/ / __ |/ , _/ ,< / /_/ /

     

  4. --________/_/ |_/_/|_/_/|_|____/___/

     

  5. INFO [io.quarkus] (main) quarkus-serverless-native 1.0.0-SNAPSHOT native

     

  6. (powered by Quarkus xx.xx.xx.) Started in 0.019s. Listening on: http://0.0.0.0:8080

     

  7. INFO [io.quarkus] (main) Profile prod activated.

     

  8. INFO [io.quarkus] (main) Installed features: [cdi, kubernetes, resteasy]

     

简直是超音速!启动只花了 19 毫秒。你的运行时间可能稍有不同。

使用 linuxps工具检测一下,结果内存占用还是很低。检测的方法是:在应用程序运行期间,另外打开一个终端,运行如下命令:

 

  1. $ ps -o pid,rss,command -p $(pgrep -f runner)

     

 

输出结果类似于:

 

  1. PID RSS COMMAND

     

  2.  

    10246 11360 target/quarkus-serverless-native-1.0.0-SNAPSHOT-runner

     

 

该进程只占 11MB 内存。非常小!

 

注意: 各种应用程序(包括 Quarkus)的驻留集大小和内存占用,都因运行环境而异,并随着应用程序载入而上升。

 

你也可以使用 REST API 访问这个函数。输出结果应该是Hello RESTEasy:

 

  1. $ curl localhost:8080/hello

     

  2. Hello RESTEasy

     

 

3、把函数部署到 Knative 服务

如果你还没有创建命名空间,现在就在 docs.okd.io(OpenShift Kubernetes 发行版) docs.okd.io(例如quarkus-serverless-native),进而把这个本地可执行文件部署为无服务器函数。然后添加quarkus-openshift扩展:

 

  1. $ ./mvnw -q quarkus:add-extension -Dextensions="openshift"

     

 

src/main/resources/Application.properties文件中添加以下内容,配置 Knative 和 Kubernetes 的相关资源:

 

  1. quarkus.container-image.group=quarkus-serverless-native

     

  2. quarkus.container-image.registry=image-registry.openshift-image-registry.svc:5000

     

  3. quarkus.native.container-build=true

     

  4. quarkus.kubernetes-client.tRust-certs=true

     

  5. quarkus.kubernetes.deployment-target=knative

     

  6. quarkus.kubernetes.deploy=true

     

  7. quarkus.openshift.build-strategy=docker

     

构建本地可执行文件,并把它直接部署到 OKD 集群:

 

  1. $ ./mvnw clean package -Pnative

     

注意: 提前使用 oc login 命令,确保登录的是正确的项目(例如 quarkus-serverless-native)。

 

输出信息结尾应当是BUILD SUCCESS。完成一个本地二进制文件的构建并部署为 Knative 服务需要花费几分钟。成功创建服务后,使用kubectloc命令工具,可以查看 Knative 服务和版本信息:

 

  1. $ kubectl get ksvc

     

  2. NAME URL [...]

     

  3. quarkus-serverless-native http://quarkus-serverless-native-[...].SUBDOMAIN True

     

  4. $ kubectl get rev

  5. NAME CONFIG NAME K8S SERVICE NAME GENERATION READY REASON

  6. quarkus-serverless-native-00001 quarkus-serverless-native quarkus-serverless-native-00001 1 True

 

4、访问本地可执行函数

运行kubectl命令,搜索无服务器函数的节点:

 

  1. $ kubectl get rt/quarkus-serverless-native

     

 

输出信息类似于:

 

  1. NAME URL READY REASON

     

  2. quarkus-serverless-native http://quarkus-serverless-restapi-quarkus-serverless-native.SUBDOMAIN True

     

curl命令访问上述信息中的URL字段:

 

  1. $ curl http://quarkus-serverless-restapi-quarkus-serverless-native.SUBDOMAIN/hello

     

过了不超过一秒钟,你也会得到跟本地操作一样的结果:

 

  1. Hello RESTEasy

     

当你在 OKD 群集中访问 Quarkus 运行中的节点的日志,你会发现本地可执行文件正在以 Knative 服务的形式运行。

Native Quarkus Log

下一步呢?

你可以借助 GraalVM 发行版优化 Java 无服务器函数,从而在 Knative 中使用 Kubernetes 将它们部署为无服务器函数。Quarkus 支持在普通的微服务中使用简易配置进行性能优化。

本系列的下一篇文章将指导你在不更改代码的情况下跨多个无服务器平台实现可移植函数。

(Daniel Oh, creativecommons.org)

via:

作者: 选题: 译者: 校对:

本文由 原创编译, 荣誉推出

LCTT 译者 :cool-summer-021

翻译: 4.0 篇

贡献: 33 天

2022-09-22

2022-10-24

https://linux.cn/lctt/cool-summer-021

欢迎遵照 CC-BY-SA 协议规定转载,

如需转载,请在文章下留言 “ 转载:公众号名称”,

我们将为您添加白名单,授权“ 转载文章时可以修改”。



Tags:Kubernetes   点击:()  评论:()
声明:本站部分内容及图片来自互联网,转载是出于传递更多信息之目的,内容观点仅代表作者本人,不构成投资建议。投资者据此操作,风险自担。如有任何标注错误或版权侵犯请与我们联系,我们将及时更正、删除。
▌相关推荐
Kubernetes 究竟有没有 LTS?
从一个有趣的问题引出很多人都在关注的 Kubernetes LTS 的问题。有趣的问题2019 年,一个名为 apiserver LoopbackClient Server cert expired after 1 year[1] 的 issue 中提...【详细内容】
2024-03-15  Search: Kubernetes  点击:(6)  评论:(0)  加入收藏
Kubernetes 集群 CPU 使用率只有 13% :这下大家该知道如何省钱了
作者 | THE STACK译者 | 刘雅梦策划 | Tina根据 CAST AI 对 4000 个 Kubernetes 集群的分析,Kubernetes 集群通常只使用 13% 的 CPU 和平均 20% 的内存,这表明存在严重的过度...【详细内容】
2024-03-08  Search: Kubernetes  点击:(19)  评论:(0)  加入收藏
聊聊 Kubernetes 网络模型综合指南
这篇详细的博文探讨了 Kubernetes 网络的复杂性,提供了关于如何在容器化环境中确保高效和安全通信的见解。译自Navigating the Network: A Comprehensive Guide to Kubernete...【详细内容】
2024-02-19  Search: Kubernetes  点击:(39)  评论:(0)  加入收藏
Kubernetes Informer基本原理,你明白了吗?
本文分析 k8s controller 中 informer 启动的基本流程不论是 k8s 自身组件,还是自己编写 controller,都需要通过 apiserver 监听 etcd 事件来完成自己的控制循环逻辑。如何高...【详细内容】
2024-01-30  Search: Kubernetes  点击:(40)  评论:(0)  加入收藏
Kubernetes 100个常用命令!
这篇文章是关于使用 Kubectl 进行 Kubernetes 诊断的指南。列出了 100 个 Kubectl 命令,这些命令对于诊断 Kubernetes 集群中的问题非常有用。这些问题包括但不限于:&bull; 集...【详细内容】
2024-01-03  Search: Kubernetes  点击:(78)  评论:(0)  加入收藏
管理 Kubernetes 集群这3年,我踩过的十个坑
作者 | Herve Khg编译 | 如烟出品 | 51CTO技术栈(微信号:blog51cto) Kubernetes 作为云计算领域的绝对主角,当仁不让地坐上了容器技术领域的“头把交椅”。它的精髓在于,你只要在...【详细内容】
2023-12-15  Search: Kubernetes  点击:(168)  评论:(0)  加入收藏
在 Kubernetes 中无侵入安装 OpenTelemetry 探针,你学会了吗?
OpenTelemetry 探针OpenTelemetry(简称 Otel,最新的版本是 1.27) 是一个用于观察性的开源项目,提供了一套工具、APIs 和 SDKs,用于收集、处理和导出遥测数据(如指标、日志和追踪信...【详细内容】
2023-12-07  Search: Kubernetes  点击:(174)  评论:(0)  加入收藏
Kubernetes 的调试功能 ,别慌:debug 不行,还有superdebug
这篇内容主要探讨了 Kubernetes 的调试功能,介绍了 kubectl debug 和 kubectl superdebug。它们支持容器挂载并且能够调试一些需要排查问题的 Pod。文章指出了在 Kubernetes...【详细内容】
2023-12-06  Search: Kubernetes  点击:(216)  评论:(0)  加入收藏
Kubernetes 中的服务注册与发现原理分析
对k8s有点了解技术人员,应该都只知道k8s是有服务注册发现的,今天就分析下这个原理,看看怎么实现的。什么是服务注册与发现服务注册与发现是一种机制,用于在集群中动态地发现和连...【详细内容】
2023-11-30  Search: Kubernetes  点击:(165)  评论:(0)  加入收藏
普通Kubernetes Secret足矣
众所周知,Kubernetes secret 只是以 base64 编码的字符串,存储在集群的其余状态旁边的 etcd 中。自 2015 年引入 secret 以来,安全专家就一直在嘲笑这一决定,并寻求其他替代方案...【详细内容】
2023-11-30  Search: Kubernetes  点击:(177)  评论:(0)  加入收藏
▌简易百科推荐
Docker 和传统虚拟机有什么区别?
我有一个程序员朋友,他每年情人节都要送女朋友一台服务器。他说:“谁不想在过节当天收到一台 4核8g 的服务器呢?”“万一对方不要,我还能留着自己用。” 给他一次过节的机会,他能...【详细内容】
2024-03-26  小白debug  微信公众号  Tags:Docker   点击:(12)  评论:(0)  加入收藏
掌握Docker网络驱动程序:优化容器通信
Docker为在容器内包装、交付和运行应用程序提供了一个强大的平台,从而彻底改变了容器化。网络是容器化的重要组成部分,Docker提供了各种网络驱动程序来支持容器之间的通信以...【详细内容】
2024-03-22    51CTO  Tags:Docker   点击:(11)  评论:(0)  加入收藏
Containerd容器管理
Nginx 指定容器名称 使用 ctr container create 命令创建容器后,容器并没有处于运行状态,其只是一个静态的容器。容器基本操作容器基本操作主要是 ctr image 命令,查看命令帮...【详细内容】
2024-03-20  云原生运维圈  微信公众号  Tags:容器   点击:(13)  评论:(0)  加入收藏
如何基于Docker镜像逆向生成Dockerfile
引言你是否曾经遇到过一个想要使用的 Docker 镜像,但却无法修改以适应你的特定需求?或者你可能发现了一个喜欢的 Docker 镜像,但想要了解它是如何构建的?在这两种情况下,将 Docke...【详细内容】
2024-03-07  云原生运维圈  微信公众号  Tags:Docker   点击:(23)  评论:(0)  加入收藏
Kubernetes是什么?主要特点是什么?
Kubernetes是什么?Kubernetes,也称为K8s,是一个开源的容器编排系统,由Google首次开发和维护。它允许容器化的应用程序在集群中自动部署、扩展和管理。Kubernetes提供了一种容器...【详细内容】
2024-02-01    简易百科  Tags:Kubernetes   点击:(162)  评论:(0)  加入收藏
我们一起聊聊容器资源自愈
在企业实际在使用容器这类资源的时候,除了技术本身,要考虑的其他问题也会很多。企业管理的容器有千千万万,出于效率考虑,对于有特殊需求的容器如何进行批量创建和管理呢,这就需要...【详细内容】
2024-01-30  匠心独运维妙维效  微信公众号  Tags:容器   点击:(47)  评论:(0)  加入收藏
Docker与Docker Compose入门:释放你应用部署的威力
今天给大家介绍一项强大而有趣的技能,那就是使用 Docker 和 Docker Compose 来释放你的应用部署的威力!无论你是一名开发人员还是系统管理员,掌握这个技能都将为你的工作带来巨...【详细内容】
2024-01-17  waynblog  微信公众号  Tags:Docker   点击:(66)  评论:(0)  加入收藏
Docker镜像与容器的交互及在容器内部执行代码的原理与实践
Docker作为一种流行的容器技术,已经成为现代应用程序开发和部署的重要工具。在Docker中,镜像是构建和运行容器的基础,而容器则是基于镜像创建的可执行实例。Docker镜像与容器的...【详细内容】
2024-01-10  编程技术汇  今日头条  Tags:Docker   点击:(79)  评论:(0)  加入收藏
如何在 Ubuntu 上安装 Docker
使用 Docker 意味着开启一个新的计算领域,但如果你刚刚开始使用 Docker,安装可能看起来是一项艰巨的任务。在 Ubuntu 上安装 Docker 有两种推荐的方法: 从 Ubuntu 的仓库安装 D...【详细内容】
2024-01-04    Linux中国  Tags:Docker   点击:(124)  评论:(0)  加入收藏
从Kubernetes的探针到DevOps
今天在群里又看有人问如何设置 Kubernetes 的探针,感觉要补充的话太多了,结合我们在一些 DevOps 项目中痛苦的体验,今天一劳永逸的全部说完,此外,也为大家展现一下为什么 DevOps...【详细内容】
2023-12-27  云云众生s  微信公众号  Tags:Kubernetes   点击:(117)  评论:(0)  加入收藏
站内最新
站内热门
站内头条