Serverless架构

news/2024/9/21 0:04:04/文章来源:https://www.cnblogs.com/lixiaoran/p/18423470

Serverless架构:漂浮在云端的轻盈与自由 

类似于 Fn Project 的 Serverless 开源服务有很多,它们都旨在简化函数即服务(FaaS)的开发流程,使得开发者可以更专注于业务逻辑而不是底层基础设施。下面列举了一些知名的 Serverless 开源平台和服务:

1. **OpenFaaS**
- OpenFaaS 是一个开放源码的平台,可以在 Kubernetes 上运行,支持多种语言,提供了一个简单的方式来部署服务器端无状态或者有状态的应用程序。

2. **Knative**
- 谷歌主导的 Knative 是一个 Kubernetes 的扩展,它提供了一组 API 和工具来帮助开发者构建、部署和管理现代应用,包括 Serverless 应用。

3. **Apache OpenWhisk**
- Apache OpenWhisk 是一个开源的分布式计算平台,它提供了事件驱动的能力,支持多种编程语言。

4. **OpenFaas Faas-netes**
- 这是 OpenFaaS 社区的一个项目,专门为 Kubernetes 设计,允许用户在一个 Kubernetes 集群上部署函数。

5. **Serverless Framework**
- 虽然主要与 AWS Lambda 结合使用,但 Serverless Framework 本身是一个用于部署 Serverless 应用程序的工具,也支持其他平台。

6. **Nuclio**
- Nuclio 是一个由 VMware 开发的开源框架,用于在 Kubernetes 上快速部署低延迟的机器学习模型和其他应用。

7. **Fission**
- Fission 是一个 Kubernetes 的 Serverless 框架,支持多种语言,并且可以很容易地与现有的 Kubernetes 集群集成。

8. **Kubeless**
- Kubeless 是一个简单的 Kubernetes 工具,用于部署和管理无服务器函数。

9. **OpenLambda**
- OpenLambda 是一个用于在任何基础设施上部署和运行 Lambda 函数的开源项目。

10. **Iron.io**
- Iron.io 提供了一系列云服务组件,包括 IronFunctions,这是一个可部署在本地或云上的无服务器平台。

 优点:轻松游走在云端的便利 
  • 极大降低运维负担:开发者无需考虑服务器的部署、管理和扩展问题,可以将更多的精力投入到核心业务的开发中。
  • 弹性扩展与计费:Serverless架构能够根据实际的需求,自动调整计算资源,而且通常只需为实际使用的资源付费。
  • 快速部署与迭代:简化了部署流程,能够更快地从开发迭代到线上运行。
缺点:自由与束缚并存 
  • 高度依赖云平台:应用的运行和稳定性在很大程度上依赖于云平台的能力和稳定性。
  • 冷启动延迟:在服务经过一段时间的不活动后,再次启动可能会面临冷启动的延迟问题。
  • 网络延迟:由于业务逻辑运行在云端,网络延迟也成为影响响应时间的因素之一。
使用场景:适应性的选择 
  • 事件驱动的计算:对于需要快速响应事件触发的计算任务,例如实时数据处理、图像处理等。
  • 轻量级的Web应用:一些不需要复杂后端支持的应用,例如静态网站、小工具或API等。
  • 临时性的大规模计算:例如在特定时间需要进行大规模数据分析的任务。
技术选型:多元的技术搭配 
  • AWS Lambda:支持多种编程语言,如Node.js、Python、Java等,并提供丰富的触发器。
  • Azure Functions:允许使用C#、Java、JavaScript等语言,并支持多种触发器和绑定类型。
  • Google Cloud Functions:侧重于事件驱动的计算,支持Node.js、Python、Go等。

Serverless架构,一种让开发者更加专注于业务开发的架构模式,虽然带有一定的依赖和局限,但同时也提供了极大的便利和自由。在某些适应的场景下,Serverless架构能够以其轻盈和敏捷,快速响应市场的变化和需求。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/800786.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

室内导航的界面该如何设计

室内导航的界面该如何设计?发点例子你看看

【笔记】机器学习算法在异常网络流量监测中的应用

这段时间在找方向,又看不懂文章,只能先从一些相对简单的综述类看起,顺便学学怎么写摘要相关工作的。机器学习算法在异常网络流量监测中的应用 原文:Detecting Network Anomalies in NetFlow Traffic with Machine Learning Algorithms 原文链接:Detecting Network Anomali…

画5.0

chino 最近摆烂过头了,博客都没有好好更新。 这位想必人尽皆知。

opencascade Bnd_OBB源码学习 OBB包围盒

opencascade Bnd_OBB OBB包围盒前言 类描述了定向包围盒(OBB),比轴对齐包围盒(AABB)更紧密地包围形状的体积。OBB由盒子的中心、轴以及三个维度的一半定义。与AABB相比,OBB在作为非干扰物体的排斥机制时可以更有效地使用。 方法 1. 空构造函数 //! 空构造函数 Bnd_OBB() …

Scala安装与环境配置详解教程

本文参考来源: http://mengmianren.com/zhihuishu2020/641069.htmlScala运行在java的JVM之上,因此需要先安装Java运行环境 一、JDK8的下载和安装及环境变量配置 使用的jdk版本是:jdk-8u191-windows-i586.exe https://pan.baidu.com/s/1RNNb7lcqKHC_2h0iiTlqFg?pwd=9t5e 提取…

day2-2

今天进行了一次小测验,仍与基础的增删改查有关。 题目的要求是通过Java写出一个建议系统,能够历遍输出各个数据,能够添加,删除,修改数据,能够根据编号查找到对应的数据。程序如下该程序能够完成这些要求,也具有一定的健全性。

大学C++程序设计课程开发指南——开发环境搭建

前言 由于某些大学程序设计课程仍然在使用VC6.0这一上古工具,不太适合学生与现代开发生产接轨,并且也有可能出现兼容问题等,故编写此文,仅供参考。 使用 Visual Studio 在介绍Visual Studio(此后简称VS)前,先给大家介绍这一工具的发展。 其前身正是VC6.0(全称Visual C++…

LLM DATASET

大模型的能力来源 https://arxiv.org/pdf/2402.18041 大模型合规来源 https://arxiv.org/html/2402.12193v2 大模型的罪恶检测来源 https://www.kaggle.com/datasets/odins0n/ucf-crime-dataset/data code math https://github.com/mlabonne/llm-datasetsMath & LogicLLMs …

2024-9-20

ArrayList类 获取元素

在链接与运行地址不同时gdb的调试方法

搭建一个链接和运行不同的环境 SECTIONS {. = 0xffff000000080000,/* . = 0x80000, */.text.boot : { *(.text.boot) }.text : { *(.text) }.rodata : { *(.rodata) }..... }-s还可以看到符号都链接到高地址去了但是elf文件中有详细的地址信息,如果后续qemu加载的是elf的话就会…

排队论——随机服务系统仿真精解

排队论作为研究随机服务系统的重要工具,专门研究系统中客户到达、排队、服务和离开的过程。排队论的核心目的是通过数学建模和分析,研究系统的性能指标,如平均等待时间、队列长度、系统的吞吐量等。虽然排队论提供了强大的数学工具来分析随机服务系统,但在许多复杂的实际问…

opencascade Adaptor3d_Curve源码学习

opencascade Adaptor3d_Curve 前言用于几何算法工作的3D曲线的根类。 适配曲线是曲线提供的服务与使用该曲线的算法所需服务之间的接口。 提供了两个派生具体类:GeomAdaptor_Curve,用于Geom包中的曲线 Adaptor3d_CurveOnSurface,用于Geom包中表面上的曲线。 用于评估BSpline…