写点什么

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:001690
用户头像

发布了 256 篇内容, 共 145.7 次阅读, 收获喜欢 576 次。

关注

评论 1 条评论

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

神级外挂 | 网络性能优化,2个补丁就足够

鼎道智联

重磅发布 | 博睿数据发布互联网行业精选案例集

博睿数据

互联网 可观测性 博睿数据 One 精选案例

人脸识别技术的分类和实现方法

来自四九城儿

倒计时1天 | 诚邀见证“九章云极DataCanvas新产品发布会”!

九章云极DataCanvas

我为什么选择多边形架构做为工程的基础思想

软件工程师-罗小东

普通人蓝海创业项目-微信朋友圈广告代理加盟 利润全给

互联网创业践行者

“Cisco Live 2023 大会”云原生观测解决方案成关键看点

乘云 DataBuff

云原生 APM 可观测性 Cisco 智能运维AIOps

起风了,泛娱乐企业出海如何正确扬帆?

ToB行业头条

为什么负数的补码等于反码加一

xzy

2023中国(抚远)冷水鱼预制菜高质量发展大会在黑龙江抚远举办

新消费日报

会是调用第三方接口那么简单吗?

高端章鱼哥

程序员 前端 接口 系统

九章云极DataCanvas公司加入中国移动信息现代产业链“十百千万”计划

九章云极DataCanvas

Docker容器共享磁盘

高端章鱼哥

Docker Linux

List的拆分的几种方式

EquatorCoco

前端 前端框架 开发框架

筑牢三大新型能源基础设施,能源变革的分水岭和路线图

脑极体

新能源

代码随想录训练营 Day02 - 数组(下)

jjn0703

算法

我在中小型项目SuperCell模式实战经验

软件工程师-罗小东

HTML5 游戏开发实战 | 俄罗斯方块

TiAmo

html html5 6 月 优质更文活动

通过构建背景图学习CSS径向渐变

南城FE

CSS 前端开发 渐变

ChatGPT与码农的机会

这我可不懂

人工智能 ChatGPT

鲲鹏入晋,乘云而起,华为开发者大会开启“山西时刻”,共话山西鲲鹏生态建设

彭飞

一文吃透MAUI、WinUI3和WPF的优势及劣势

这我可不懂

WPF MAUI

人脸识别技术在智慧城市建设中的应用

来自四九城儿

AI 和 DevOps:实现高效软件交付的完美组合

SEAL安全

AI DevOps 企业号 6 月 PK 榜

火山引擎A/B测试推出智能流量调优实验,助力汽车行业破局营销困境

字节跳动数据平台

券商数字化创新场景数据中台实践

袋鼠云数栈

数字化转型 数据治理

科兴未来|浙江丽水市第六届高层次人才创业大赛活动

科兴未来News

人脸识别技术的未来发展方向

来自四九城儿

C++实现简单的ls命令以及原理

攻城狮Wayne

es 笔记二之基础查询

Hunter熊

elasticsearch

采用Qt+Live555搭建RTSP服务器

DS小龙哥

6 月 优质更文活动

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