Dapr v1.8 正式发布
Dapr是一套开源、可移植的事件驱动型运行时,允许开发人员轻松立足云端与边缘位置运行弹性、微服务、无状态以及有状态等应用程序类型。Dapr能够确保开发人员专注于编写业务逻辑,而不必分神于解决分布式系统难题,由此显著提高生产力并缩短开发时长。Dapr降低了构建微服务架构类现代云原生应用程序的入门门槛,Dapr应用程序已经能够在生产场景中部署自托管基础设施或Kubernetes集群。当使用自托管模式部署在虚拟机环境选用Consul 作为服务发现组件时, 1.8版本解决了一个问题 : Consul 用作名称解析组件时,相同的 appid 无法实现负载平衡[1]。
2022年7月8日正式发布了1.8 版本[2],这是自从2021年2月发布首个1.0 版本以来第八次小版本更新,Dapr 1.8.0 版本的贡献者数量众多,我们要感谢所有 92位新的和现有的贡献者,他们帮助实现了这个版本。 这次更新的内容很多都是大家期盼的功能,例如分布式锁API,中间件组件的外部 WASM 支持,更多的成熟Stable组件等。接下来我们一起来看看更新的内容。
1、死信Topic:有时,由于各种原因,应用程序可能无法处理消息。例如,检索处理消息所需的数据时可能存在暂时性问题,或者应用业务逻辑无法返回错误。死信Topic[3]用于转发无法传递到订阅应用的消息。
2、分布式锁 API: 分布式锁提供对应用程序中共享资源的互斥访问。在此版本中,引入了一个新的 alpha API,使您能够在共享资源上使用互斥锁。这是践行标准API的第一个,在Dapr中,处理共享资源的互斥访问推荐采用Dapr Actor 构建块,但是呢Dapr Actor 构建块在社区的采用上比较低,一个例外就是.NET相关的Dapr 解决方案里面对于Actor的采用是非常高的,在其他的Java,go,python等等相关项目中目前采用Dapr Actor的还是很少。
3、对中间件组件的 WASM 支持: 现在,您可以使用外部 WASM 模块编写 Dapr 中间件组件,并使用非 Go 语言扩展 Dapr。
4、容错弹性策略[4]进入预览版阶段,Dapr 1.7.0 实现了容错弹性策略第一阶段目标, 1.8 版本进入预览, Dapr 的组件版本分Alpha、Preview、Stable,我们会把Stable的组件和API 投入到生产。
5、状态共享的命名空间支持:在应用程序之间共享状态时,命名空间现在可用于隔离状态。这允许具有相同命名空间的应用重用相同的状态存储。
6、元数据 API 返回组件功能列表:现在可以查询元数据 API,以获取该 sidecar 已加载的组件的功能[5],特别是 pub/sub 和 state store
7、边车证书安装支持:Dapr sidecar现在可以支持为Linux和Windows容器安装证书。
8、Kubernetes 改进:Dapr Operator 现在包括一个“看门狗”功能[6],以确保 Dapr sidecar 存在于 Pod 中,这在应用程序或集群故障期间尤其重要,以提供更高水平的弹性。部署 Dapr 时,无论是在 Kubernetes 上还是在 Docker 自托管中,提取的默认容器映像都基于distroless[7],现在,您可以使由Microsoft维护的免费开源Linux发行版和容器基础映像Mariner[8](正式名称为CBL-Mariner)的Image。
9、组件改进,在之前的 Dapr 版本中具有稳定候选版本的以下组件已升级为稳定版本
- Azure Table Storage State Store (stable candidate)
- Azure Event Hubs Binding (stable candidate)
- Azure Storage Queues Binding (stable candidate)
- Postgresql State Store (stable candidate)
- Azure Event Hubs Pubsub (stable candidate)
Dapr现在有超过100多个组件(总共105个)。此版本中添加的新组件,其中2个是华为云的组件,一个阿里的 Apache Dubbo Binding:
- 1.6 版本添加的 RouterChecker HTTP Request Routing ,已经有文档了。
- Commerce Tools Binding
- Apache Dubbo Binding
- Huawei OBS Binding
- Huawei CSMS Secret Store
- In-memory State Store used for development
- RocketMQ PubSub
- Wasm Basic HTTP Middleware
- Redis Distributed Lock
10、开发工具SDK 改进:
Python
- 支持配置 API Unsubscribe events
- 支持 per-actor-type configuration
- 支持Actor 计时器和提醒中的TTL和时间/间隔格式
Java
- 添加 pubsub routing
.NET
- 支持配置API的 Unsubscribe events
- 支持 per-actor-type configuration
- 支持 distributed lock API
JavaScript
- JavaScript SDK现在在@dapr/dapr上可用。较旧的包 dapr-client 正处于弃用的路上
- 支持 Actor reminder/timer TTL support
- 支持 Configuration API
- 支持 gRPC proxy
- 支持 configuring the SDK logger
11、CLI 改进:
- 添加了
注释CLI 命令,用于将 Dapr 注释添加到已部署的 Kubernetes 配置中。 dapr init在 k8s 模式下,现在可以使用 GHCR 和私有注册表来拉取映像- 给 Dapr version 加上了文档
如果您不熟悉 Dapr,请访问入门页面并熟悉 Dapr。 文档已更新,包含此版本的所有新功能和更改。通过概念和开发应用程序文档开始使用此版本中引入的新功能。要将 Dapr 升级到 1.8.0 版,请跳至本节。
相关链接:
[1] Consul 用作名称解析组件时,相同的 appid 无法实现负载平衡:https://github.com/dapr/components-contrib/issues/1199
[2]Dapr 1.8 版本:https://blog.dapr.io/posts/2022/07/08/dapr-v1.8-is-now-available/
[3]死信Topic:https://v1-8.docs.dapr.io/developing-applications/building-blocks/pubsub/pubsub-deadletter
[4]容错弹性策略:https://v1-7.docs.dapr.io/operations/resiliency/
[5]组件的功能:https://v1-8.docs.dapr.io/reference/api/metadata_api/#components
[6]Dapr Operator 现在包括一个“看门狗”功能:https://github.com/dapr/dapr/blob/master/charts/dapr/README.md#dapr-operator-options
[7]distroless镜像:https://github.com/GoogleContainerTools/distroless
[8]CBL-Mariner: https://github.com/microsoft/CBL-Mariner/
Dapr v1.8 正式发布的更多相关文章
- Dapr v1.9.0 版本已发布
Dapr是一套开源.可移植的事件驱动型运行时,允许开发人员轻松立足云端与边缘位置运行弹性.微服务.无状态以及有状态等应用程序类型.Dapr能够确保开发人员专注于编写业务逻辑,而不必分神于解决分布式系统 ...
- Go语言v1.8正式发布,有显著的性能提升和变化(go适合服务器编程、网络编程)
前言 Go语言现在在服务端的网络编程领域越来越火,尤其像IM即时通讯应用这种富网络应用且对服务端网络性能要求极高的场景,很高兴看到Golang发布了1.8正式版,希望在多核架构横行的时代多一些这种顺应 ...
- Dapr 官方文档中文翻译 v1.5 版本正式发布
作者:敖小剑 - Dapr Approver 经过 Dapr 中国社区十余位贡献者一个多月的努力,Dapr 官方文档中文翻译 v1.5 版本完成翻译和审校,正式发布并上线 Dapr 官网. 访问方式 ...
- Dapr 知多少 | 分布式应用运行时
Intro Dapr 官方团队已于最近(2021.1.17)正式发布Dapr v1.0,Dapr已正式生产可用,可以部署到自托管环境或 Kubernetes 集群.对于绝大多数开发者来说,想必对Dap ...
- Dapr | 云原生的抽象与实现
引言 Dapr 是微软主导的云原生开源项目,2019年10月首次发布,到今年2月正式发布 V1.0 版本.在不到一年半的时间内,github star 数达到了 1.2 万,超过同期的 kuberne ...
- 乘风破浪,.Net Core遇见Dapr,为云原生而生的分布式应用运行时
Dapr是一个由微软主导的云原生开源项目,国内云计算巨头阿里云也积极参与其中,2019年10月首次发布,到今年2月正式发布V1.0版本.在不到一年半的时间内,github star数达到了1.2万,超 ...
- 分布式应用运行时 Dapr 1.7 发布
Dapr 是一个开源.可移植的.事件驱动的运行时,可以帮助开发人员构建在云和边缘上运行的弹性的.微服务的.无状态和有状态应用程序,并且关注于业务逻辑而不用考虑分布式相关的问题. 分布式相关的问题交给D ...
- Dapr 弹性的策略
云原生应用需要处理 云中很容易出现瞬时故障.原因在以下文档 暂时性故障处理[1] 中有具体说明. 任何环境.任何平台或操作系统以及任何类型的应用程序都会发生暂时性故障. 在本地基础结构上运行的解决方案 ...
- Qunee for HTML5 v1.6新版本发布
Qunee for HTML5 V1.6正式发布,修复了一些 BUG,增加了滚动条支持,改进了编辑器,增加了JSON 导入导出.告警冒泡.连线流动,UI 定制等扩展示例,欢迎 访问 导航面板 增加了滚 ...
随机推荐
- 03. 树莓派初始配置——安装vim编辑器
安装vim编辑器 树莓派系统默认是不带vim编辑器的,默认安装的vi编辑器在编辑文档的时候用得特别不舒服,对人体的血压和树莓派的寿命影响较大. 解决办法:一行命令 1. 安装vim编辑器 sudo a ...
- Python 函数进阶-高阶函数
高阶函数 什么是高阶函数 高阶函数就是能够把函数当成参数传递的函数就是高阶函数,换句话说如果一个函数的参数是函数,那么这个函数就是一个高阶函数. 高阶函数可以是你使用def关键字自定义的函数,也有Py ...
- OCI runtime exec failed: exec failed: container_linux.go:380: starting container process caused: exec: "ip": executable file not found in $PATH: unknown (Docker容器没有ip addr命令:exec ip addr 报错)
一.报错 1.报错信息1: OCI runtime exec failed: exec failed: container_linux.go:380: starting container proce ...
- 微信小程序绑定函数如何携带参数
一开始以为微信小程序的语法是和VUE的语法一样的,直接@click="click(field)",结果却不是这样的 在微信小程序中我们需要设置一个 data-set ,然后在绑定的 ...
- 使用 Swoole 加速你的 CMS 系统,并实现热更新 (基于 Laravel 框架)
主题:使用 Swoole 加速你的 CMS 系统,并实现热更新 关于 Swoole 的简介不再在此赘述,各位可以自行查看官网的文档进行详细的了解. 本文以 MyCms 为例,简要说明 Swoole 结 ...
- 并发编程系列之Lock锁可重入性与公平性
一.相似之处:Lock锁 vs Synchronized 代码块 Lock锁是一种类似于synchronized 同步代码块的线程同步机制.从Java 5开始java.util.concurrent. ...
- 【Unity Shader学习笔记】Unity基础纹理-法线贴图
1 高度纹理 使用一张纹理改变物体表面法线,为模型提供更多细节. 有两种主要方法: 1.高度映射:使用一张高度纹理(height map)来模拟表面位移(displacement).得到一个修改后的法 ...
- CabloyJS - GitHub Readme
简体中文 | English CabloyJS CabloyJS是一款顶级NodeJS全栈业务开发框架, 基于KoaJS + EggJS + VueJS + Framework7 文档 官网 & ...
- torch.ones_like(),expand_as(),expend()等torch.repeat
https://blog.csdn.net/Arthur_Holmes/article/details/104267662 https://blog.csdn.net/weixin_39568781/ ...
- ExtJS 同行表单域对齐有误处理办法
更新记录 2022年5月29日 第一次编辑.使用的ExtJS版本:ExtJS 7.4 问题 原本都是显示正常的表单域,比如这些文本框.选择框都是正常. 在用户进行操作,然后显示验证提示后,明显出现了问 ...