前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >分布式应用运行时 Dapr 1.7 发布

分布式应用运行时 Dapr 1.7 发布

作者头像
张善友
发布2022-04-28 18:58:56
7580
发布2022-04-28 18:58:56
举报
文章被收录于专栏:张善友的专栏

Dapr 是一个开源、可移植的、事件驱动的运行时,可以帮助开发人员构建在云和边缘上运行的弹性的、微服务的、无状态和有状态应用程序,并且关注于业务逻辑而不用考虑分布式相关的问题。 分布式相关的问题交给Dapr来解决。

2022年4月8日正式发布了1.7 版本, 这是这是自Dapr v1.0 发布以来的第七次小版本更新,Dapr 1.7.0 版本的贡献者数量最多。我们要感谢所有 83 位新的和现有的贡献者,他们帮助实现了这个版本。 这次更新的内容很多都是大家期盼的功能,例如支持离线部署、更多的成熟Stable组件等,接下来我们一起来看看更新的内容。

1、跨 Dapr API 配置重试、超时和断路器 ,这部分我也写了一篇文章: Dapr 弹性的策略,Dapr 1.7.0 实现了第一阶段目标。分布式应用程序通常由许多服务组成,任何给定应用程序都有数十个甚至数百个实例。这些应用程序并非孤立存在,而是多次依赖于数据库、缓存、发布/订阅、秘密存储和其他基础设施服务。随着更多的依赖关系,系统故障的可能性增加。例如,由于硬件故障、数据库运行缓慢、请求数量过多、应用程序重新启动/横向扩展或其他几个原因,实例可能会失败或无响应。设计和实施具有容错能力(检测、缓解和响应故障的能力)的应用程序可以使您的应用程序恢复到正常运行状态并自我修复,还有助于防止级联故障一直到您的基础设施服务。

Dapr 提供了通过弹性规范定义和应用容错弹性策略的能力。弹性规范保存在与组件规范相同的位置,并在 Dapr sidecar 启动时应用。Sidecar确定如何将弹性策略应用于您的 Dapr API 调用。在弹性规范中,您可以为流行的弹性模式定义策略,例如:

  • 超时
  • 重试
  • 断路器

然后可以将策略一致地应用于目标,其中包括:

  • 通过服务调用的应用程序
  • 组件
  • Actor

2、在可观测性方面进一步加强,为了提高操作的可见性,组件中添加了新的指标,包括发布/订阅、绑定、状态存储等。例如:

  • 使用组件时的延迟。
  • 调用给定组件的次数。
Dapr 运行时将事件记录到标准输出以便于诊断;例如,列出启动时加载的组件的其他运行时信息。使用此版本,您现在可以:

3、组件改进,在之前的 Dapr 版本中具有稳定候选版本的以下组件已升级为稳定版本,特别是MQTT 发布订阅组件的进入稳定状态,对于在边缘计算的采用提供了一个非常好的支持:

在这个版本中添加了3个状态组件,一共有23个状态组件了,华为云也开始提交了一个新的状态组件,1.8 版本会成为新增的状态组件。

在现有组件中加入了新的功能:

influxdb绑定现在支持查询。在这个版本中,现在共有 97 个组件,包括 41 个绑定、1 个配置、8 个 HTTP 中间件、3 个名称解析、13 个 pub/sub、8 个秘密存储和 23 个状态存储。

4、功能从预览版移至稳定版

在至少两个版本可用并征求反馈和修复后,一些功能从预览状态转移到稳定状态。此版本中的以下功能现已稳定:

  • Actor重入
  • gRPC 代理
  • 自动状态存储加密,包括添加对使用 128 位、192 位和 256 位密钥大小的新支持。

5、CLI 更新

Kubernetes 命名空间支持

CLI 的命令 components, configurations, 和 list 在返回的输出结果中支持Kubernetes的命名空间

简化新根证书和应用程序证书的更新:

  • 引入了dapr mtls renew-certificate命令,可以更轻松地解决集群中的根证书到期和续订问题。
  • -k如果根证书到期时间不足 30 天,任何使用 Kubernetes 选项的 CLI 命令现在都会引发警告消息。

6、在自托管模式下安装 Dapr 的新方法

私有和备用映像注册表(预览) 在自托管模式下,CLI init命令现在可以:

  • 指定任何私有注册表以提取安装 Dapr 所需的容器Image。
  • 提供选择公共 Docker hub 或 Github 存储库的能力。这使您能够:
    • 将Image放置在您选择的受信任存储库中。
    • 在Image 限制的情况下从不同的公共资源中提取。

离线安装(预览版)

默认情况下,Dapr 会下载二进制文件并从网络中提取Image 以设置开发环境。在此版本中,Dapr 现在支持使用预下载的制品进行离线 安装,无论是使用 Docker 还是silm环境。每个 Dapr 版本的制品现在都内置在Dapr Installer Bundle中,可以从 repo :https://github.com/dapr/installer-bundle 下载。通过将此安装程序包与 Dapr CLI  init命令一起使用,从而实现离线安装。

7、性能改进

Unix 域套接字现在在 Kubernetes 上可用,现在,您可以在使用注释  dapr.io/unix-domain-socket-path 调用 Dapr sidecar 时将 Unix Domain Sockets 与 Kubernetes(以及自托管)一起使用,以提高吞吐量并降低延迟。

如果您不熟悉 Dapr,请访问入门页面并熟悉 Dapr。 文档已更新,包含此版本的所有新功能和更改。通过概念和开发应用程序文档开始使用此版本中引入的新功能。要将 Dapr 升级到 1.7.0 版,请跳至本节

更多详情,参见  https://github.com/dapr/dapr/releases/tag/v1.7.0

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022-04-13,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 1、跨 Dapr API 配置重试、超时和断路器 ,这部分我也写了一篇文章: Dapr 弹性的策略,Dapr 1.7.0 实现了第一阶段目标。分布式应用程序通常由许多服务组成,任何给定应用程序都有数十个甚至数百个实例。这些应用程序并非孤立存在,而是多次依赖于数据库、缓存、发布/订阅、秘密存储和其他基础设施服务。随着更多的依赖关系,系统故障的可能性增加。例如,由于硬件故障、数据库运行缓慢、请求数量过多、应用程序重新启动/横向扩展或其他几个原因,实例可能会失败或无响应。设计和实施具有容错能力(检测、缓解和响应故障的能力)的应用程序可以使您的应用程序恢复到正常运行状态并自我修复,还有助于防止级联故障一直到您的基础设施服务。
    • Dapr 运行时将事件记录到标准输出以便于诊断;例如,列出启动时加载的组件的其他运行时信息。使用此版本,您现在可以:
      • Unix 域套接字现在在 Kubernetes 上可用,现在,您可以在使用注释  dapr.io/unix-domain-socket-path 调用 Dapr sidecar 时将 Unix Domain Sockets 与 Kubernetes(以及自托管)一起使用,以提高吞吐量并降低延迟。
      相关产品与服务
      容器服务
      腾讯云容器服务(Tencent Kubernetes Engine, TKE)基于原生 kubernetes 提供以容器为核心的、高度可扩展的高性能容器管理服务,覆盖 Serverless、边缘计算、分布式云等多种业务部署场景,业内首创单个集群兼容多种计算节点的容器资源管理模式。同时产品作为云原生 Finops 领先布道者,主导开源项目Crane,全面助力客户实现资源优化、成本控制。
      领券
      问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档