这7个开源平台帮你入手无服务器计算

译文
服务器 开源 云计算
无服务器常常与FaaS(函数即服务)这个术语互换使用。但无服务器并不意味着没有服务器。事实上有好多服务器,即公共云提供商提供为你部署、运行和管理应用程序的服务器。

【51CTO.com快译】无服务器一词最近出现在更多的对话中。不妨澄清一下这个概念及相关的概念,比如无服务器计算和无服务器平台。

无服务器常常与FaaS(函数即服务)这个术语互换使用。但无服务器并不意味着没有服务器。事实上有好多服务器,即公共云提供商提供为你部署、运行和管理应用程序的服务器。

无服务器计算是新兴的类别,代表开发人员构建和交付软件系统的方式发生了转变。通过代码将应用软件基础设施抽取出来可大大简化开发过程,同时在成本和效率方面带来新的好处。我认为,无服务器计算和FaaS将在与云原生服务和混合云一同帮助定义企业IT的下一个时代方面发挥重要作用。

[[249819]]

无服务器平台提供的API让用户可以运行代码函数(又叫操作),并返回每个函数的结果。无服务器平台还提供HTTPS端点,让开发人员可以检索函数结果。这些端点可以用作其他函数的输入,从而提供一连串相关函数。

在大多数无服务器平台上,用户在部署(或创建)函数后再执行函数。然后,无服务器平台拥有被告知执行时执行函数所需的所有代码。用户可以通过命令手动调用无服务器函数的执行,也可以由事件源触发,事件源被配置成一旦遇到计划任务警报、文件上载或其他许多事件之类的事件,就激活函数。

入手无服务器计算的7个开源平台

1.Apache OpenWhisk

Apache OpenWhisk是一个无服务器开源云平台,让你可以执行代码以响应任何规模的事件。它用Scala语言编写。该框架处理来自HTTP请求等触发器的输入,然后运行一小段JavaScript或Swift代码。

2.Fission

Fission是一个无服务器计算框架,使开发人员能够使用Kubernetes构建函数。它让程序员可以用任何编程语言编写短暂的函数,并将这些函数映射到任何事件触发器(比如HTTP请求)。

3.IronFunctions

IronFunctions是一个无服务器计算框架,通过集成其现有服务和拥抱Docker,提供了一个连贯一致的微服务平台。开发人员用Go语言来编写函数。

4.Fn Project

Fn Project是一个开源容器原生无服务器平台,可以在任何地方运行它:任何云或内部环境。它易于使用,支持各种编程语言,还具有可扩展性和高性能。

5.OpenLambda

OpenLambda是一个采用Apache许可证的无服务器计算项目,用Go编写,基于Linux容器。OpenLambda的主要目标是让用户能够探究无服务器计算的新方法。

6.Kubeless

Kubeless是一个Kubernetes原生无服务器框架,让你可以部署少量代码,无需担心底层基础设施。它利用Kubernetes资源来提供自动扩展、API路由、监控和故障排除等功能。

7.OpenFaas

OpenFaas是一个用Docker和Kubernetes构建无服务器函数的框架,为指标提供一流的支持。任何进程可以打包成函数,那样你就可以使用众多Web事件,无需重复编写样板代码。

Kubernetes是管理无服务器工作负载和微服务应用容器的最流行平台,使用精细的部署模型以便更快速、更轻松地处理工作负载。使用Knative Serving(https://github.com/knative/serving),你可以在Kubernetes上构建和部署无服务器应用程序和函数,并使用Istio(https://istio.io/)来扩展和支持高级场景,比如:

  • 快速部署无服务器容器
  • 自动扩展和缩小到零
  • 面向Istio组件的路由和网络编程
  • 已部署的代码和配置的时间点快照

Knative(https://github.com/knative/)专注于在云原生平台上构建和运行应用程序的常见任务,用于编排源代码到容器构建、将服务绑定到事件生态系统、部署期间路由和管理流量以及自动扩展工作负载。

Istio是一个开放平台,用于连接和保护微服务(在Envoy代理看来实际上就是服务网格控制平面),并旨在考虑与框架交互的多个角色,包括开发人员、操作人员和平台提供者。

比如说,你可以使用以下代码片段,在本地Minishift(https://github.com/minishift/minishift)平台上使用Knative Serving部署JavaScript无服务器工作负载: 

## Dockerfile 
FROM bucharestgold/centos7-s2i-nodejs:10.x 
WORKDIR /opt/app-root/src 
COPY package*.json ./ 
RUN npm install 
COPY . . 
EXPOSE 8080 3000 
CMD ["npm""start"
 
 
## package.json 

  "name""greeter"
  "version""0.0.1"
  "private"true
  "scripts": { 
    "start""node app.js" 
  }, 
  "dependencies": { 
    "express""~4.16.0" 
  } 

 
## app.js 
var express = require("express"); 
var app = express(); 
 
var msg = (process.env.MESSAGE_PREFIX || "") + "NodeJs::Knative on OpenShift"
 
app.get("/"function(req, res, next) { 
  res.status(200).send(msg); 
}); 
 
app.listen(8080, function() { 
  console.log("App started in port 8080"); 
}); 
 
## service.yaml 
apiVersion: serving.knative.dev/v1alpha1 
kind: Service 
metadata: 
  name: greeter 
spec: 
  configuration: 
    revisionTemplate: 
      spec: 
        container: 
          image: dev.local/greeter:0.0.1-SNAPSHOT 
  • 1.
  • 2.
  • 3.
  • 4.
  • 5.
  • 6.
  • 7.
  • 8.
  • 9.
  • 10.
  • 11.
  • 12.
  • 13.
  • 14.
  • 15.
  • 16.
  • 17.
  • 18.
  • 19.
  • 20.
  • 21.
  • 22.
  • 23.
  • 24.
  • 25.
  • 26.
  • 27.
  • 28.
  • 29.
  • 30.
  • 31.
  • 32.
  • 33.
  • 34.
  • 35.
  • 36.
  • 37.
  • 38.
  • 39.
  • 40.
  • 41.
  • 42.
  • 43.
  • 44.
  • 45.
  • 46.
  • 47.
  • 48.

构建你的Node.js无服务器应用程序,并将服务部署到本地Kubernetes平台上。在Kubernetes(或Minishift)上安装Knative、Istio和Knative Serving这些必要的基本组件。过程如下:

1.使用以下命令连接到Docker守护程序:

(minishift docker-env) && eval(minishift oc-env) 
  • 1.

2.使用以下命令和Jib(https://github.com/GoogleContainerTools/jib)构建无服务器应用程序容器映像:

./mvnw -DskipTests clean compile jib:dockerBuild 
  • 1.

3.将Minishift等无服务器服务部署到Kubernetes集群:

kubectl apply -f service.yaml 
  • 1.

结论

上面这个例子表明了在哪里并如何借助Kubernetes、Knative Serving和Istio之类的云原生平台开始开发无服务器应用程序。

原文标题:7 open source platforms to get started with serverless computing,作者:Daniel Oh

【51CTO译稿,合作站点转载请注明原文译者和出处为51CTO.com】

责任编辑:未丽燕 来源: 51CTO.com
相关推荐

2018-11-20 10:44:10

开源无服务器 Serverless

2022-01-05 09:28:31

无服务器计算服务器应用程序

2019-04-30 10:27:46

无服务器云计算安全

2023-08-25 13:25:00

云计算云平台

2018-03-01 10:26:25

无服务器计算架构

2022-03-18 20:54:24

无服务器计算无服务器服务器

2019-04-01 13:47:57

无服务器计算云服务

2020-02-13 11:29:46

服务器架构技术

2019-03-08 10:26:29

无服务器云计算德勤

2018-02-28 11:19:41

服务器云计算公共云

2017-11-27 10:45:48

无服务器计算容器

2018-05-02 09:00:26

开源 Web 服务器

2018-10-17 09:08:58

无服务器计算Oracle

2023-08-27 15:20:58

Serverless架构开发

2023-07-05 08:00:45

架构

2022-07-01 13:41:32

无服务器容器企业

2020-10-10 07:00:00

无服务器计算容器

2020-03-25 11:06:46

无服务器开源安全工具

2018-02-24 10:15:36

无服务器容器云计算

2017-08-08 14:33:36

无服务计算服务器
点赞
收藏

51CTO技术栈公众号