OpenFunction v1.0.0 发布:集成 WasmEdge,支持 Wasm 函数和更完整的 CI/CD

OpenFunction 是一个开源的云原生 FaaS(Function as a Service,函数即服务)平台,旨在帮助开发者专注于业务逻辑的研发。今天,我们非常高兴地宣布 OpenFunction 迎来了一次重要的更新,即 v1.0.0 版本的发布!

In this update, we continue to focus on providing developers with more flexible and powerful tools, and have added some new features on this basis. This release
本次更新中,我们继续致力于为开发者们提供更加灵活和强大的工具,并在此基础上加入了一些新的功能点。其中,该版本集成了 WasmEdge 以支持 Wasm 函数;我们还对 OpenFunction 的 CI/CD 功能进行了增强,提供了相对完整的端到端的 CI/CD 功能;除此之外,我们还在这个版本中新增了从本地代码直接构建函数或应用的镜像的功能,让开发者可以更加便捷地进行代码发布和部署。

与此同时,我们也在大力优化 OpenFunction 的性能和代码质量,使其更加稳定高效。

以下是本次版本更新的主要内容:

集成 WasmEdge,支持 Wasm 函数

WasmEdge 是一个轻量级、高性能和可扩展的 WebAssembly 运行时,适用于云原生、边缘和去中心化应用程序。它为 Serverless 应用程序、嵌入式功能、微服务、智能合约和物联网设备提供支持。

OpenFunction 现在支持构建和运行以 WasmEdge 为运行时的 Wasm 函数或应用。WasmEdge 成为 Docker、Containerd 和 CRI-O 之外的容器运行时的新选择。

Wasm 函数示例

cat <<EOF | kubectl apply -f -
apiVersion: core.openfunction.io/v1beta1
kind: Function
metadata:
  name: wasmedge-http-server
spec:
  workloadRuntime: wasmedge
  image: openfunctiondev/wasmedge_http_server:0.1.0
  imageCredentials:
    name: push-secret
  build:
    dockerfile: Dockerfile
    srcRepo:
      revision: main
      sourceSubPath: functions/knative/wasmedge/http-server
      url: https://github.com/OpenFunction/samples
  port: 8080
  route:
    rules:
      - matches:
          - path:
              type: PathPrefix
              value: /echo
  serving:
    runtime: knative
    scaleOptions:
      minReplicas: 0
    template:
      containers:
        - command:
            - /wasmedge_hyper_server.wasm
          imagePullPolicy: IfNotPresent
          livenessProbe:
            initialDelaySeconds: 3
            periodSeconds: 30
            tcpSocket:
              port: 8080
          name: function
EOF

借助 WasmEdge 引擎,开发者可以使用多种支持 Wasm 的语言和开发框架来编写及运行函数。

如何构建和运行 Wasm functions,请参考官方文档 Wasm Functions

更完整的 CI/CD

之前,用户可以使用 OpenFunction 将函数或应用程序源代码构建为容器镜像,然后直接将构建的镜像部署到底层的同步或异步 Serverless 运行时,而无需用户干预。

但是,OpenFunction 不能在函数或应用程序源代码发生更改时重新构建镜像并重新部署它,也不能在镜像更改时重新部署它(例如手动构建和推送镜像或在其他函数中构建镜像)。

从 v1.0.0 开始,OpenFunction 在新的组件 Revision Controller 中增加了检测源代码或镜像变更的能力,并且可以在检测到变更后触发镜像重新构建或重新部署新的镜像。Revision Controller 的能力包括:

  • 检测 GitHub、GitLab 或 Gitee 中的源代码变更,然后在源代码变更时重新构建并重新部署新的镜像。
  • 检测包含源代码的镜像(Bundle Container Image)的变更,然后在该镜像变更时重新构建和重新部署新的镜像。
  • 检测函数或应用程序镜像变更,然后在函数或应用程序镜像变更时重新部署新的镜像。

更好的 CI/CD 功能确保了代码能在不同的环境中高效运行,使用者可以在开发和部署过程中更好的控制版本和代码质量,同时也为使用者提供了更好的使用体验。

此处请参考官方文档 CI/CD

从本地源代码构建函数

目前,OpenFunction v1.0.0 支持根据本地的源代码构建函数或应用。只需要将本地源代码打包到容器镜像中,并将此镜像推送到容器注册表即可完成构建。以下为操作方法。

假设你的源代码在 samples 目录中,你可以根据以下 Dockerfile 来构建包含源代码的镜像。

FROM scratch
WORKDIR /
COPY samples samples/

然后如下操作:

docker build -t <your registry name>/sample-source-code:latest -f </path/to/the/dockerfile> .
docker push <your registry name>/sample-source-code:latest

推荐使用空镜像 scratch 作为基础镜像构建包含源代码的镜像,非空基础镜像可能会导致源代码拷贝失败。

另外还需要定义字段 spec.build.srcRepo.bundleContainer.image

apiVersion: core.openfunction.io/v1beta1
kind: Function
metadata:
  name: logs-async-handler
spec:
  build:
    srcRepo:
      bundleContainer:
        image: openfunctiondev/sample-source-code:latest
      sourceSubPath: "/samples/functions/async/logs-handler-function/"

sourceSubPath 是包含源代码的镜像中源代码的绝对路径。

其他的改进和优化

除了上述的主要变化,该版本还有以下更改和增强:

  • OpenFunction
    • 核心 API v1alpha2 已弃用并删除
    • 将 sha256 添加到服务镜像
    • 将构建源信息添加到函数状态
    • 将 Shipwright 升级到 v0.11.0
    • 将 Knative 升级到 v0.32.0
    • 将 Dapr 升级到 v1.8.3
    • 将 Go 升级到 v1.18
  • functions-framework-java 发布 V1.0.0
    • 在一个 pod 中支持多个函数
    • 支持自动发布
  • Builder
    • 在一个 pod 中支持多个函数
    • 将默认的 Java 框架版本更新为 1.0.0
  • revision-controller 发布 v1.0.0(功能见上文)

以上就是 OpenFunction v1.0.0 的主要功能变化,在此十分感谢各位贡献者的参与和贡献。如果您正在寻找一款高效、灵活的云原生函数开发平台,那么 OpenFunction v1.0.0 将是您的绝佳选择。

了解更多关于 OpenFunction 和本次版本更新的信息,欢迎访问我们的官方网站和 Github 页面。

本文由博客一文多发平台 OpenWrite 发布!

原文链接:https://www.cnblogs.com/kubesphere/p/17225716.html

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:OpenFunction v1.0.0 发布:集成 WasmEdge,支持 Wasm 函数和更完整的 CI/CD - Python技术站

(0)
上一篇 2023年4月18日
下一篇 2023年4月18日

相关文章

  • Python线程池模块ThreadPoolExecutor用法分析

    Python线程池模块ThreadPoolExecutor用法分析 对于需要执行大量I/O型任务,使用多线程可以有效提高程序性能的同时,也存在着线程创建与销毁所带来的额外开销、资源竞争和同步问题等问题。线程池技术可以有效地缓解这些问题。Python中线程池的实现有很多,其中“ThreadPoolExecutor”是Python3内置的线程池实现,本文将详细讲…

    云计算 2023年5月18日
    00
  • ASP.NET开源导入导出库Magicodes.IE完成Csv导入导出的方法

    一、引言 ASP.NET是一种基于Web的应用程序框架,旨在开发动态网站。而Magicodes.IE则是一种用于操作Excel、Csv和Html的开源库,使用简单方便,实现了导入、导出、数据验证等功能。本文将对使用Magicodes.IE完成Csv导入导出的完整攻略进行详细讲解。 二、安装 在软件安装时,通过NuGet安装Magicodes.IE库并引用到项…

    云计算 2023年5月17日
    00
  • ASP.NET Core使用NLog记录日志

    ASP.NET Core使用NLog记录日志 在ASP.NET Core应用程序中,记录日志是非常重要的。NLog是一个流行的日志记录库,可以帮助我们记录日志。本文将提供一个完整的攻略,包括如何使用NLog记录日志。以下是详细步骤: 步骤1:安装NLog 在使用NLog之前,我们需要安装NLog。以下是一个示例说明,演示如何安装NLog: dotnet ad…

    云计算 2023年5月16日
    00
  • PHP5.5迭代生成器用法实例详解

    PHP5.5迭代生成器用法实例详解 迭代器模式简介 在开发过程中,遍历许多复杂的数据结构,最常用的方法是使用foreach循环语句。通常情况下,foreach语句中的数组是由其他函数或对象返回的。 在PHP语言中,可以通过自定义实现能够遍历复杂数据结构的对象,这个对象就是迭代器。迭代器是一种实现了特定接口的类,能够遍历一些特定的数据结构。迭代器的应用可以轻松…

    云计算 2023年5月18日
    00
  • Python实现压缩和解压缩ZIP文件的方法分析

    当需要将多个文件合并成一个文件传输或存储时,压缩文件是一个非常有效的方式。ZIP是一种被广泛使用的文件格式,可以减小文件大小,并可以方便地打包和解压文件。 Python实现压缩ZIP文件 Python内置的zipfile模块提供了一种简单的方法来创建和压缩ZIP文件。下面是使用zipfile实现压缩ZIP文件的步骤。 步骤一:导入zipfile模块 使用Py…

    云计算 2023年5月18日
    00
  • 使用ASP.NET Web API构建Restful API

    使用ASP.NET Web API构建Restful API的完整攻略包括以下步骤: 步骤1:创建ASP.NET Web API项目 首先,我们需要在Visual Studio中创建一个新的ASP.NET Web API项目。在Visual Studio打开后,选择”File” -> “New” -> “Project”,在弹出的对话框中选择”A…

    云计算 2023年5月17日
    00
  • 互联网科技大佬推荐的12本必读书籍

    以下是“互联网科技大佬推荐的12本必读书籍”的完整攻略,包括背景介绍、书籍列表、示例说明等。 1. 背景介绍 互联网科技大佬们经常会推荐一些好书,这些书籍不仅可以帮助我们了解互联网行业的发展趋势,还可以提高我们的思维能力和创新能力。下面是12本互联网科技大佬推荐的必读书籍。 2. 书籍列表 以下是12本互联网科技大佬推荐的必读书籍: 《黑客与画家》:作者是P…

    云计算 2023年5月16日
    00
  • 读书笔记丨理解和学习事务,让你更好地融入云原生时代

    摘要:分布式事务与云原生技术有很强的关联,可以帮助云原生应用程序实现高效的分布式事务处理。 本文分享自华为云社区《理解和学习事务,让你更好地融入云原生时代》,作者: breakDawn。 随着云原生的概念越来越火,服务的架构应该如何发展和演进,成为很多程序员关心的话题。大名鼎鼎的《深入理解java虚拟机》一书作者于21年推出了新作《凤凰架构》,从这本书中可以…

    云计算 2023年5月8日
    00
合作推广
合作推广
分享本页
返回顶部