50万奖金+官方证书,深圳国际金融科技大赛正式启动,点击报名 了解详情
写点什么

CloudState:用于 Knative/Kubernetes 的开源无服务器框架

  • 2019-09-23
  • 本文字数:1077 字

    阅读完需:约 4 分钟

CloudState:用于Knative/Kubernetes的开源无服务器框架

Lightbend 最近发布了 CloudState。CloudState 是首个可用于对 Knative/Kubernetes 堆栈进行状态管理的开源无服务器(serverless)框架。


据 Jonas Bonér 所说:


CloudState 是一个围绕状态管理通过添加概念、模型和实现来定义什么是“serverless 2.0”(或者下一代 serverless 是什么)的倡议。任何构建过云应用程序(分布式系统)的人都知道,状态实际上是最难处理的,而到目前为止,serverless 或多或少会忽略状态管理这一点。所以我们试着把它和两件事情结合起来。首先是标准化工作,为实现这些功能定义规范、协议和 TCK。其次是参考实现,实现规范。


CloudState 基本上由两部分组成:标准化工作,定义用户函数与后端之间的规范、协议和 TCK;以及一个参考实现,它用多种语言实现了后端和一组客户端的 API 库。


CloudState 是为基于事件驱动的架构、事件源、CQRS、集群分片、数据和处理协同定位、CRDTs 以及其他常见的分布式模式而设计的。此外,CloudState 的参考实现利用了运行在 kubernetes 上的KnativegRPCAkka集群GraalVM ,这不仅使应用程序能够有效地伸缩,而且还能使应用程序在保持其全局或本地数据一致性的同时,在一定范围内可靠地管理分布式状态。


让我们看下 CloudState 服务是怎样的:



(图片来自https://github.com/cloudstateio


  • Ingress(入口)——可以是 Istio、Knative、或 Kubernetes 中常规的 ClusterIP 服务通信

  • Akka Sidecar(Akka 侧车)——由 CloudState 操作符注入;每个请求都会经过它。单个 CloudState 服务的 sidecars 形成一个集群,使用 Akka remoting 彼此直接通信。

  • Code(代码)——由开发人员实现的函数。它可以用任何支持 gRPC 的语言编写。Akka sidecars 使用预定义的 gRPC 协议与用户函数通信。

  • Distributed Datastore (分布式数据存储)——当服务需要持久化状态时使用。需要注意的是,用户代码并不直接与数据存储交互,它先是与 Akka sidecars 交互,Akka sidecars 再与数据存储通信。


CloudState 实现了自己的自动容量伸缩器,使用 Knative 的自动容量伸缩器进行实验时,一旦对 Akka 集群进行扩容就会带来一些问题,其中一个问题是当添加新节点时,会重新平衡切分,并复制状态。一次启动太多的节点或者是只启动节点而不立即停止它们时,将会显著降低吞吐量和性能。


有关 CloudState 的更多详细信息可以查看GitHub repo。它还有一个示例应用程序,是用JavaJavaScript实现的简单聊天程序。


想要贡献力量的用户可以订阅邮件列表,加入Gitter频道进行讨论,或者通过Twitter进行联系。


原文链接:


CloudState, an Open Source Serverless Framework for Knative/Kubernetes


2019-09-23 08:002191
用户头像

发布了 550 篇内容, 共 395.6 次阅读, 收获喜欢 721 次。

关注

评论 1 条评论

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

如何利用YashanDB提升企业数据处理能力?

数据库砖家

Playwright MCP浏览器自动化教程

测试人

人工智能 软件测试

如何利用YashanDB数据库实现决策支持系统

数据库砖家

如何配置YashanDB实现高可用容灾架构?

数据库砖家

BOE(京东方)携新能源领域新品亮相2025服贸会 引领绿色转型新动能

爱极客侠

海外APP开发的注意事项

北京木奇科技有限公司

软件外包公司 APP外包开发 海外APP开发

厂不大,事不少?中小企业如何用MES打通生产管理“任督二脉”

万界星空科技

数字化 mes 中小企业数字化转型 中小型制造业 数字化转型‘’

如何配置YashanDB实现多租户数据隔离管理

数据库砖家

通过jobleap.cn的岗位信息预测 A 股金融市场行业景气度从而炒股赚钱​

Y11

赚钱 找工作 研究 找实习 炒股

成语答题赚系统详情

微擎应用市场

如何配置YashanDB实现自动化数据库运维?

数据库砖家

海外 App 开发的注意事项

北京木奇科技有限公司

软件外包公司 APP外包公司 海外APP

如何利用YashanDB实现企业数据的智能管理?

数据库砖家

如何利用YashanDB数据库实现数据安全加密?

数据库砖家

如何配置YashanDB实现数据实时同步功能?

数据库砖家

如何评估YashanDB数据库在云服务中的表现

数据库砖家

如何使用YashanDB进行企业培训的效果评估?

数据库砖家

适合小型企业的项目管理系统推荐:Reddit 用户真实需求

NocoBase

开源 项目管理 低代码 项目管理系统 小型企业

如何利用YashanDB实现实时数据备份与恢复

数据库砖家

如何利用YashanDB数据库的聚合功能

数据库砖家

如何利用YashanDB数据库实现数据的快速恢复与备份

数据库砖家

轻工业是否需要采购堡垒机需求简单分析

行云管家

网络安全 等保 堡垒机

如何利用YashanDB数据库管理大规模数据集

数据库砖家

如何利用YashanDB数据库进行复杂查询与分析

数据库砖家

如何实现YashanDB数据库的零停机升级?

数据库砖家

如何使用YashanDB的API与第三方应用程序集成?

数据库砖家

从二维码到 RFID,企业该怎么选?

斯科信息

RFID技术 RFID读写器 RFID标签 RFID手持终端 RFID天线

快速搞定Dify+Chrome MCP:打造能操作网页的AI助手

测吧(北京)科技有限公司

如何利用YashanDB数据库提高数据处理的并发能力

数据库砖家

如何评估YashanDB在企业数据管理中的成效?

数据库砖家

如何设置YashanDB的自动化任务以简化数据操作

数据库砖家

CloudState:用于Knative/Kubernetes的开源无服务器框架_服务革新_Diogo Carleto_InfoQ精选文章