写点什么

最热开源无服务器函数:五大 Fission 架构参考

  • 2019-01-03
  • 本文字数:2220 字

    阅读完需:约 7 分钟

最热开源无服务器函数:五大Fission架构参考

“无服务器”现在是极具诱惑的技术趋势,没有什么比管理服务器更让人痛苦。亚马逊、微软和谷歌都在云中提供无服务器专有接口。相较于这些云供应商的商业化产品,开源无服务器架构可免于被云厂商锁定,但要以牺牲云便利性和易用性为代价。


近一年,Fission 热度颇高。简单来讲,Fission 是一个构建在 Kubernetes 之上的 FaaS 或 Serverless 函数框架。Fission 使用配有动态装载器的标准容器把 Kubernetes 与内部容器联系在一起,所使用的功能被放置于适当的标准容器中,并被加载以回答容器内 Web 服务器查询。


因为其灵活且不会被锁定到特定云提供商,Fission 已被应用到多个行业,本文将介绍五大行业常见用例的 Fission 架构设计模式。


参考架构 1:物联网(IoT)


从工业互联网到可穿戴设备再到智能汽车,一系列物理设备(传感器、执行器,智能设备和可穿戴设备…)收集各种类型数据,并与数据中心内运行的应用程序进行通信。通常,数据使用网关聚合,然后发送到可分析这些变量的平台以获取业务洞察(性能、趋势、触发事件等)。


物联网应用程序中的整体流程可使用 Fission 编排:


  1. 使用网关聚合数据,并将其发送到在 Kubernetes 上托管运行的 Kafka 服务器集群消息队列;

  2. 基于整个管道流程调用 Fission 函数:


  • 对于放置在消息队列中的给定文件,文件内容将传递到 Fission 函数,该函数首先对其标准化以提取感兴趣的变量,然后将输出发送到 NoSQL 数据库或文件系统;

  • 第二个函数将运行以响应 NoSQL 数据库中的标准化文件。该函数将读取文件内容,根据需要执行计算(基于用例),调用执行功能的微服务,例如将数据发送到 Data Lake 或 Data Mart 以进一步分析;

  • 可以为事件流中任何类型的处理操作编写分支函数,FaaS 可根据数据量按比例放大或缩小。


参考架构 2:金融服务(支付处理,风险计算等)


金融服务行业可以使用基于 Fission 的无服务器架构实时处理支付请求、执行合规性检查和风险度量等关键任务。


金融应用程序中的整体流程可以使用 Fission 编排:


  1. 开发人员将 Fission 部署为跨多个应用程序的共享功能,这些程序是支付处理网关前端,可处理用户身份验证、注册和支付相关数据收集;

  2. 系统将后端与存放交易数据的数据库进行连接;

  3. 创建 Fission 函数以解析具有以下变量的给定输入数据流:用户信用卡数据、交易位置、其它用户信息等。


  • 第一个函数调用欺诈检测 API,并根据检查结果将数据保存到内存数据网格中;

  • 无论检查通过还是失败,均调用第二组函数。如果检查通过,则该函数批准付款并向用户发送确认;

  • 如果怀疑付款存在欺诈性,则会调用另一个函数向后端欺诈检测系统发出告警。


参考架构 3:Web 应用程序扩充


绝大多数企业应用都是三层 Web 程序,这些应用是业务后台及技术任务(如备份、告警、数据收集)的接口。新兴模式是用无服务器 Fission 函数来处理这些任务,而不影响单片 n 层应用程序的开发和部署。


Web 应用程序扩充的总体流程可以使用 Fission 函数编排:


  1. 业务用户继续与(传统)应用程序连接,但可以利用 Fission 函数提供的增强功能;

  2. 为一系列计算和数据处理任务创建新功能;

  3. 主要应用程序触发这些功能,因为需要机会性执行;

  4. Dedicated 函数执行所描述的适当逻辑,如果需要,向应用程序报告。


这可以被视为将传统应用程序重构或分解为微服务的好方法,或者轻松添加不依赖“mother ship”开发和发布过程的附加功能。


参考架构 4:传统系统改造


诸如大型机和 n 层应用之类的传统系统在银行、保险、零售等行业普遍存在并且根深蒂固。由于复杂性、业务依赖性、重构需要大量时间和精力以及这些系统仍然表现良好且具有成熟的使用模式等事实,企业不可能简单撕掉和替换这些系统。为了确保与现代服务(如 Web 和移动应用程序)的互操作性,Fission 函数可以围绕这些系统提供基于标准的 API 包装器。


例如:


  1. 请求被发送到 API 网关,API 网关执行基本转换并根据请求端点需要调用 Fission 函数;

  2. 函数接收输入数据(例如 JSON)并将其转换为终端系统可处理的格式,然后调用(传统)业务系统;

  3. 一旦系统响应,函数可获取并将其转换为源系统理解的格式,再使用适当的响应调用 API 网关。


参考架构 5:使用 Apache Spark 进行机器学习


对于大多数公司而言,机器学习和预测分析通常针对组织内的特定项目。为了实现机器学习的真正价值,跨应用共享数据、算法和模型是有利的。Fission 可以与 Apache Spark 等技术结合,提供最终用户或应用程序所使用的流处理和趋势预测数据。


使用 Fission 和 Apache Spark 编排机器学习应用整体流程:


  1. 业务运营数据实时提取到基于 Kafka 的消息队列集群;

  2. Spark Streaming 以微批方式获取数据,通常基于时间窗口。此数据存储在数据湖中以进行批处理分析,并发送到 Spark MlLib 运行时,其中存储了不同的预测模型;

  3. 这些模型基于在 Spark 上运行的通用 ML 算法,比如有监督和无监督算法 ,聚类、分类算法等;

  4. 一旦将模型结果写入 NoSQL 数据库或内存数据网格,就会触发 Fission 函数;

  5. Fission 函数执行一系列关键业务功能,例如,更新业务分析仪表板,发送实时服务等。


结论


无服务器正在成为继 Kubernetes 之后最热门的趋势之一,开源无服务器解决方案使用高度灵活的技术,基于标准 PaaS 平台解决行业面临的业务挑战,并可在本地和任意公有云运行。但是,与其他新技术一样,无服务器仍然存在一些问题,比如可扩展性、生态系统集成等,如何合理搭建成为技术人员需要思考的重要问题。


参考链接:https://dzone.com/articles/what-is-serverless-part-5-reference-architectures


2019-01-03 08:2010075
用户头像
赵钰莹 极客邦科技 总编辑

发布了 909 篇内容, 共 704.5 次阅读, 收获喜欢 2706 次。

关注

评论 1 条评论

发布
暂无评论
发现更多内容

揭秘新一代云数仓技术架构与最佳实践

字节跳动数据平台

大数据 数据仓库 云原生 OLAP 数据仓库服务

MegEngine 动态执行引擎-Imperative Runtime 概述

MegEngineBot

深度学习 开源 动态图 MegEngine

肝到爆!通过Canal如何优雅的将MySQL同步到ES?

Java全栈架构师

Java MySQL 程序员 后端 ES

做开发5年,这8个高效开发好习惯我悟了🔥

引迈信息

程序员 前端 低代码 JNPF

下载量破 15000!龙蜥社区登陆阿里云 ACR 制品中心 TOP5 榜单

OpenAnolis小助手

阿里云 操作系统 容器镜像 龙蜥社区 Dragonwell

优质高效!阿里内部超高质量的k8s+Jenkins笔记,技术与实战齐飞

程序知音

提升效率:P4VFS让虚拟文件同步更迅速、更简单

龙智—DevSecOps解决方案

文件同步 虚拟文件同步 Virtual File Sync

怎样区分试验与仿真的关系?

思茂信息

仿真软件 仿真技术

一篇关于代码质量的实用攻略!

飞算JavaAI开发助手

代码质量 软件开发、

打卡有礼!快来 2023 开放原子全球开源峰会找龙蜥玩~

OpenAnolis小助手

开源 操作系统 龙蜥社区 开放原子全球开源峰会 龙蜥实验室

软件测试/测试开发丨Allure2报告中添加附件-图片

测试人

程序员 软件测试 测试开发 Allure

运维人员福音!自定义插件为运维提供更多可能

嘉为蓝鲸

#运维 Python运维 Linux 运维

2023上海国际嵌入式展 | 如何通过人工智能驱动的自动化测试工具提升嵌入式开发效率

龙智—DevSecOps解决方案

嵌入式 嵌入式软件 嵌入式设计 嵌入式开发

NFT全链游戏dapp系统开发合约定制

开发v-hkkf5566

TDengine 合作伙伴 +1,这次是「DaoCloud道客」

爱倒腾的程序员

涛思数据 时序数据库 ​TDengine

几个小技巧,提高你的代码质量

飞算JavaAI开发助手

代码质量 程序员、 软件开发、

备战金九银十:大厂面试官必问MySQL连环炮全梳理,你扛得住嘛?

程序员小毕

Java MySQL 数据库 程序员 面试

嘉为蓝鲸研运一体化解决方案入选“鑫智奖”

嘉为蓝鲸

智能硬件 蓝鲸 金融数据

【羊城晚报】WeOps智慧护航,传媒“领头羊”业务迈向新高度

嘉为蓝鲸

IT运维 传媒 传媒公司

Vue.js 最佳实践:提高性能和减少耦合的方法

xfgg

JavaScript Vue 前端 6 月 优质更文活动

软件测试丨Allure2报告中添加用例支持tags标签、失败重试功能

测试人

程序员 软件测试 测试开发 测试用例 Allure

看过才知道,这套SpringCloudAlibaba笔记,把微服务玩的出神入化!

程序知音

Java 微服务 SpringCloud java架构 后端技术

PAG动效框架源码笔记 (五)渲染流程

olinone

ios android 动效 渲染

聚焦 AIGC,函数计算为 AI 应用插上腾飞翅膀

Serverless Devs

Serverless FC AIGC

如何保障医疗机器人的功能与安全?这几条编码标准你一定要了解

龙智—DevSecOps解决方案

医疗机器人 编码标准

国外云主机:为你的业务提供全球级托管!

一只扑棱蛾子

云主机

迈向新时代的英特尔代工服务:走差异化路径,坚持客户至上

最新动态

华为云GaussDB,如何为企业数字创新保驾护航?

YG科技

直播倒计时1天 | 一体化智能可观测平台如何保障电商节大促

博睿数据

电商 智能运维 博睿数据 直播预告

想让ChatGPT和低代码开发实现完美结合?看这篇文章就行!

加入高科技仿生人

低代码 数字化 ChatGPT

最热开源无服务器函数:五大Fission架构参考_服务革新_赵钰莹_InfoQ精选文章