大家好!今天给大家带来一个好消息,Dapr(Distributed Application Runtime)1.15版本正式发布啦!对于不熟悉Dapr的朋友来说,Dapr是一个开源的、跨平台的运行时,它简化了微服务架构中的许多复杂问题,比如服务发现、配置管理、状态管理等。那么,Dapr 1.15版本都带来了哪些新特性和改进呢?让我们一起来看看吧!

1. Dapr Workflow(稳定版)

首先,Dapr Workflow在1.15版本中正式进入稳定阶段。这意味着你现在可以放心地使用Dapr Workflow来编写长期运行的有状态应用,而不用担心它会“翻车”。Workflow不仅支持持久化执行,还能实现动态扩展,让你的应用在运行时可以根据需求增加或减少副本数,同时还能保持任务的持久性。这对于需要处理大量复杂业务逻辑的应用来说,简直是个福音!

2. Dapr Actors重写

在1.15版本中,Dapr Actors的运行时引擎也进行了重写。虽然API层面没有变化,但这次重写显著提高了Actor在大规模和动态扩展环境中的可靠性和稳定性。更棒的是,这次重写还为未来实现更多高级Actor API和与其他系统的集成打下了坚实的基础。

3. Scheduler Service(稳定版)

Scheduler Service是Dapr中用于调度作业的控制平面服务,它在1.15版本中也正式稳定了。这意味着你可以放心地在生产环境中使用它来管理你的定时任务或周期性作业。现在,当你升级到1.15版本时,所有新的Actor提醒都会默认使用Scheduler Service,而不再是之前的Placement Service。当然,你也可以通过配置来选择是否迁移现有的Actor提醒。

4. Conversation API(Alpha版)

Dapr 1.15还引入了一个新的Conversation API(目前处于Alpha阶段)。这个API可以帮助你更轻松地与大型语言模型(LLM)进行交互,比如OpenAI的GPT系列模型。通过Conversation API,你可以发送提示和接收LLM的响应,同时还支持性能优化和安全功能,比如缓存提示以减少调用次数和隐藏个人信息(PII)以保护隐私。

5. SDK改进

在SDK方面,各个语言的SDK都进行了不同程度的更新和改进。比如:

  • .NET SDK:增加了对Jobs、Conversation和流式Pub/Sub API的支持,同时支持.NET 9。
  • Python SDK:增加了对流式Pub/Sub API和Conversation API的支持,还引入了Mock actors用于单元测试。
  • Java SDK:增加了Spring Boot集成,支持自动注入DaprClient和DaprWorkflowClient等。
  • Go SDK:增加了对Conversation API的支持,同时Workflow的编写和管理也达到了稳定状态。

6. 升级指南

如果你已经在使用Dapr,并且想要升级到1.15版本,那么不用担心,Dapr团队已经为你准备了详细的升级指南。无论你是在本地机器上运行Dapr,还是在Kubernetes集群中部署Dapr,都可以按照指南轻松完成升级。当然,升级过程中可能会遇到一些不兼容的变更,所以请务必仔细阅读升级指南中的“Breaking Changes”部分。

结语

总的来说,Dapr 1.15版本带来了许多令人兴奋的新特性和改进。无论是Workflow的稳定版发布,还是Scheduler Service的成熟应用,都让我们看到了Dapr在微服务架构中的巨大潜力。如果你还没有尝试过Dapr,那么现在正是一个好时机!赶紧来体验一下这个强大的微服务运行时吧!

最后说个冷笑话:使用Dapr后,你的代码量可能减少,但头发量一定会增加。1.15版本更推荐搭配咖啡饮用。官方博客文章有更详细的内容:https://blog.dapr.io/posts/2025/02/27/dapr-v1.15-is-now-available/

白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了的更多相关文章

  1. 面试都在问的「微服务」「RPC」「服务治理」「下一代微服务」一文带你彻底搞懂!

    ❝ 文章每周持续更新,各位的「三连」是对我最大的肯定.可以微信搜索公众号「 后端技术学堂 」第一时间阅读(一般比博客早更新一到两篇) ❞ 单体式应用程序 与微服务相对的另一个概念是传统的「单体式应用程 ...

  2. 「 从0到1学习微服务SpringCloud 」03 Eureka的自我保护机制

    系列文章(更新ing): 「 从0到1学习微服务SpringCloud 」01 一起来学呀! 「 从0到1学习微服务SpringCloud 」02 Eureka服务注册与发现 Eureka的高可用需要 ...

  3. 「 从0到1学习微服务SpringCloud 」10 服务网关Zuul

    系列文章(更新ing): 「 从0到1学习微服务SpringCloud 」06 统一配置中心Spring Cloud Config 「 从0到1学习微服务SpringCloud 」07 RabbitM ...

  4. 「 从0到1学习微服务SpringCloud 」09 补充篇-maven父子模块项目

    系列文章(更新ing): 「 从0到1学习微服务SpringCloud 」06 统一配置中心Spring Cloud Config 「 从0到1学习微服务SpringCloud 」07 RabbitM ...

  5. 「 从0到1学习微服务SpringCloud 」08 构建消息驱动微服务的框架 Spring Cloud Stream

    系列文章(更新ing): 「 从0到1学习微服务SpringCloud 」01 一起来学呀! 「 从0到1学习微服务SpringCloud 」02 Eureka服务注册与发现 「 从0到1学习微服务S ...

  6. 「 从0到1学习微服务SpringCloud 」07 RabbitMq的基本使用

    系列文章(更新ing): 「 从0到1学习微服务SpringCloud 」01 一起来学呀! 「 从0到1学习微服务SpringCloud 」02 Eureka服务注册与发现 「 从0到1学习微服务S ...

  7. 「 从0到1学习微服务SpringCloud 」06 统一配置中心Spring Cloud Config

    系列文章(更新ing): 「 从0到1学习微服务SpringCloud 」01 一起来学呀! 「 从0到1学习微服务SpringCloud 」02 Eureka服务注册与发现 「 从0到1学习微服务S ...

  8. 「 从0到1学习微服务SpringCloud 」05服务消费者Fegin

    系列文章(更新ing): 「 从0到1学习微服务SpringCloud 」01 一起来学呀! 「 从0到1学习微服务SpringCloud 」02 Eureka服务注册与发现 「 从0到1学习微服务S ...

  9. 「 从0到1学习微服务SpringCloud 」04服务消费者Ribbon+RestTemplate

    系列文章(更新ing): 「 从0到1学习微服务SpringCloud 」01 一起来学呀! 「 从0到1学习微服务SpringCloud 」02 Eureka服务注册与发现 「 从0到1学习微服务S ...

  10. 「 从0到1学习微服务SpringCloud 」02 Eureka服务注册与发现

    系列文章(更新ing): 「 从0到1学习微服务SpringCloud 」01 一起来学呀! Spring Cloud Eureka 基于Netflix Eureka做了二次封装(Spring Clo ...

随机推荐

  1. django模型层(orm相关知识点)

    目录 一.模型层之前期准备 模型层的了解 模型 模型层的前置知识点 二.ORM常用关键字 三.ORM执行SQL语句 四.神奇的双下划线查询 五.ORM外键字段的创建 复习MySQL外键关系 外键字段的 ...

  2. 自用Idea内存配置

    自用Idea内存配置 如下: 使用了zgc,自用48g内存的mac.可以应对8后端4前端同时使用. -Xms1g -Xmx12g -XX:+UseLargePages -XstartOnFirstTh ...

  3. 【数据库】MySQL的一些基础知识

    ALTER TABLE 表名 DROP 属性名 删除数据表 DROP TABLE 数据库名.表名; 用户管理 创建用户 CREATE USER 'username'@'host' IDENTIFIED ...

  4. shell内置字符串替换

    shell变量赋值语法: 使用规则 解释单引号 所见即所得,即输出时会将单引号内的所有內容都原样输出,或者描述为单引号里面看到的是什么就会输出什么,这称为强引用双引号 (默认) 输出双引号内的所有内容 ...

  5. Error: Application Server not specified

    在IDEA中tomcat不能运行,点开Edit Configuration发现如下图情况:tomcat图标猫上有个红叉,且下面有警告提示:Error: Application Server not s ...

  6. jacoco-实战篇-增量覆盖率

    我fork的jacoco源码改造好:https://github.com/exmyth/jacoco 入口:https://github.com/exmyth/jacoco/blob/master/o ...

  7. Qt编写的项目作品29-RTSP播放器+视频监控(海康SDK版本)

    一.功能特点 支持播放视频流和本地MP4文件. 支持句柄和回调两种模式. 多线程显示图像,不卡主界面. 自动重连网络摄像头. 可设置边框大小即偏移量和边框颜色. 可设置是否绘制OSD标签即标签文本或图 ...

  8. 如何通过C#修改Windows操作系统时间

    C#的System.DateTime类提供了对日期时间的封装,用它进行时间的转换和处理很方便,但是我没有在其中找到任何可以用来修改系统时间的成员.用过VC.VB等的朋友可能知道,我们可以调用Win32 ...

  9. java通过apache poi框架读取2007版Excel文件

    java系读写excel文件既可以用jxl库,也可以用POI库,但是,jxl库只支持低版本的excel2003,不支持更高版本,无法直接输出*.xlsx文件,只能输出*.xls文件,另外,更新也不频繁 ...

  10. 携程技术分享:亿级流量的办公IM及开放平台技术实践

    本文由携程技术Jim分享,原题"日访问过亿,办公IM及开放式平台在携程的实践",下文进行了排版和内容优化. 1.引言 携程内部的办公IM项目最早在2016年立项,经历了初期简单办公 ...