CAP 发布 5.0 版本正式发布

前言

今天,我们很高兴宣布 CAP 发布 5.0 版本正式版。同时我们也很高兴的告诉你 CAP 已经有越来越多的用户并且变得越来越流行。

在 5.0 版本中,我们主要致力于更好的支持 .NET 5 以及支持新的 Transport,同时在该版本也进行了一些 Bug 修复的工作。
自从 5.0 版本发布预览版以来,也过去了几个月的时间,在这些的时间里,我们也发布了几个预览版本,感谢这些使用预览版并向我们报告 Bug 和反馈问题的用户。

那么,接下来我们具体看一下吧。

总览

可能有些人还不知道 CAP 是什么,老规矩来一个简介。

CAP 是一个用来解决微服务或者分布式系统中分布式事务问题的一个开源项目解决方案(https://github.com/dotnetcore/CAP)同样可以用来作为 EventBus 使用,该项目诞生于2016年,目前在 Github 已经有超过 4500 Star以及超过 75万 的下载量,已经在越来越多公司的和项目中得到应用。

如果你想对 CAP 更多了解,请查看我们的 官方文档。

本次在 CAP 5.0 版本中我们主要带来了以下新特性:

  • 适配 .NET 5 和 .NET Standard 2.1

  • 增加了对 NATS Transport 的支持

  • 替换 Newtonsoft.Json 为 System.Text.Json

  • 在 RabbitMQ 中启用发布确认

  • 在 RabbitMQ 中支持创建 lazy 队列的选项。

  • 在 Kafka 中,启动将会自动创建 Topic。

  • 添加自定义 Group 和 Topic 前缀的选项。

  • 更新依赖的 NuGet 包到最新版本

  • 数个 Bug 修复

适配 .NET 5 和 .NET Standard 2.1

虽然上一个版本也能够在 .NET 5 的项目中使用,但是在这个版本中我们升级到了我们以来的 NuGet 包到 .NET 的版本,并且调整到了对 .NET Standard 2.1 的支持以便于我们可以利用新特性。

感谢 @rezabayesteh 对此提提交的 PR.

增加了对 NATS Transport 的支持

根据我们的 issue 投票,我们决定在这个版本中对NATS提供支持。

NATS 是一个简单,安全,高性能的开源消息传递系统,适用于云原生应用,IoT消息传递和微服务架构,目前也是 CNCF 下的一个项目。

你可以在文档中看到更多介绍:https://cap.dotnetcore.xyz/user-guide/zh/transport/nats/

集成方式:

services.AddCap(x =>
{...x.UseNATS("");
});

替换 Newtonsoft.Json 为 System.Text.Json

在这个版本中, 我们将 Newtonsoft.Json 替换为了 System.Text.Json。

System.Text.Json 由.NET 官方提供,它提供高性能,低分配且符合标准的功能来处理Json,其中包括使用内置的UTF-8支持将对象序列化为JSON文本和反序列化JSON文本为对象。它还提供用于读取和写入编码为UTF-8的JSON文本的类型,以及创建内存中文档对象模型(DOM)的类型,以便在数据的结构化视图中随机访问JSON元素。

Transport 中的改动

RabbitMQ

在 RabbitMQ 中启用发布确认

以下内容来自官方网站:

如果RabbitMQ节点在将消息写入磁盘之前失败,则可能会丢失持久消息。例如,请考虑以下情形:

  • 客户端将持久消息发布到持久队列

  • 客户端使用队列中的消息(请注意消息是持久的,队列是持久的),但确认未激活,

  • 代理节点发生故障并重新启动,并且

  • 客户端重新连接并开始使用消息

此时,客户端可以合理地假设该消息将再次传递。情况并非如此:重新启动已导致代理丢失消息。为了保证持久性,客户应使用确认。如果发布者的频道处于确认模式,则发布者不会收到丢失消息的确认消息(因为该消息尚未写入磁盘)。

基于以上原因,我们启动了发布确认,很明显这会降低一定的性能。

在 RabbitMQ 中支持创建 lazy 队列的选项

RabbitMQ 在 3.1.6 引入了 lazy queue的概念,用于将消息尽早的转移到磁盘,然后在消费的时候才加载到 RAM 中。

具体可以查看这里的介绍:https://www.rabbitmq.com/lazy-queues.html

集成方式:

services.AddCap(x =>
{...x.UseRabbitMQ(aa =>{...aa.QueueArguments.QueueMode = "lazy";});
}

Kakfa

Kafka 中,启动将会自动创建 Topic

由于 confluent-kafka-dotnet#1366 的原因,在首次启动 Kakfa 客户端的时候会出现
Error: Broker: Unknown topic or partition 的异常,我们没有再等待官方修复这个问题,而且采取了其他的解决办法。

在 Kafka Transport 启动的时候,我们会自动向 Kakfa Broker 进行 Topic 的注册,以便于当消息来时候可以及时接收到而不必多次启动应用程序来创建Topic。

相关 issue : https://github.com/dotnetcore/CAP/issues/795

添加自定义 Group 和 Topic 前缀的选项

在一些场景中需要对Group或者Topic 进行区分,特别是AWS SQS由于不同项目都是使用的同一个云服务来共享SNS和SQS,所以这种情况下进行添加前缀就更加直观的看出来。

在本版本中,我们支持了自定义对Group和Topic的前缀添加功能,感谢 @AndriiLab 对此PR提供的支持。

其他

其他的一些改进项目包括:

1、我们将所有的 nuget 的依赖包都升级到了最新版本。

2、修复了一些已知的Bug,你可以在这里看到。

总结

以上,就是本版本中支持的一些新特性,感谢大家的支持,我们很开心能够帮助到大家
。大家在使用的过程中遇到问题希望也能够积极的反馈,帮助CAP变得越来越好。????

如果你喜欢这个项目,可以通过下面的连接点击 Star 给我们支持。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/303609.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

电脑上的ofd格式文件如何打开呢_OFD格式的文件怎么打开预览?,来充电吧

我们不管是在工作、学习、下载资源的时候都可能收到别人的文件,但是如果是word或者pfd格式还好,直接在电脑上就可以打开,但是如果是ofd格式的就很难打开了。工具/材料搜狗浏览器、DCS文档在线预览操作方法01打开我们的搜狗浏览器,…

SUSE Linux系统安全配置十条

SUSE由于其出色的性能和对安全较好的控制,吸引了很多企业级用户,目前在国内开始有大量的关键应用。但这并不代表SUSE在使用中就是安全的,SUSE里还有很多安全细节要注意。 目录 1. 补丁、SSH及其它……………………………………3 2. 最小化xi…

用Python画中国地图(二)

在上一篇文章《用Python画一个中国地图》中,我们简单描述了一下如何用Python快速画出一个中国地图的轮廓,似乎没有什么实用价值,这一次我们用实际数据填充它,使它看上去更有意义。上色延续上一次的代码,我们这次还是只…

攻城时服务器维护,8月31日服务器维护更新公告

亲爱的《千年3》玩家:2017年8月31日10:00-14:00将对全区进行服务器例行维护,预计所需时间约为4个小时,如在维护期间无法完成维护内容,开机时间将顺延。本次更新内容包含:1、商城礼包更新2、版本…

php7 匿名继承类_PHP7中的匿名类使用方法_后端开发

PHP 微服务集群搭建 - Hyperf_后端开发Hyperf 是基于 Swoole 4.4 实现的高性能、高灵活性的 PHP 协程框架,内置协程服务器及大量常用的组件,性能较传统基于 PHP-FPM 的框架有质的提升,提供超高性能的同时,也保持着极其灵活的可扩展…

MySql里的My是指谁?

Monty 是一个编程天才。19岁的时候就从赫尔辛基理工大学退学并找了份全职工作,因为在学校里已经不能再教他什么了。33岁的时候他发布了 MySQL,世界上最有名的开源数据库,除了一个库之外,他编写了数据库的全部东西。55岁的时候他抛…

要嫁就嫁程序猿——钱多话少死的早

1程序猿问科比:“你为什么这么成功? ”科比:“你知道洛杉矶凌晨四点是什么样子吗? ”程序猿:“知道,一般那个时候我还在写代码,怎么了?”科比:“额…….”2女神&#xff…

成员函数指针与高性能的C++委托

成员函数指针与高性能的C委托 http://www.cnblogs.com/jans2002/archive/2006/10/13/528160.html Member Function Pointers and the Fastest Possible C Delegates 撰文:Don Clugston 翻译:周翔 引子 标准C中没有真正的面向对象的函数指针。这一点对C来…

k8s滚动升级_k8s deployment 滚动更新

正常来说 k8s 的 deployment 在更新时默认就会进行滚动的升级但是实际操作中会发现,滚动更新过程中应用还是会“挂掉”一会儿,大概会有几秒钟网页访问 502。究其原因应该是容器启动后,到应用真正工作起来,中间会有一段时间&#x…

ajax上传文件 获取失败,Ajax上传文件/照片时报错TypeError :Illegal invocation的解决方法...

本篇文章给大家带来的内容是关于Ajax上传文件/照片时报错TypeError :Illegal invocation的解决方法,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。问题Ajax上传文件/照片时报错TypeError :Illegal in…

再见!微软宣布终止对旧版 Microsoft Edge 浏览器的支持

微软宣布自 2021 年 3 月 9 日起终止对旧版 Microsoft Edge(Microsoft Edge Legacy)浏览器的支持。旧版 Microsoft Edge 是基于 EdgeHTML 的浏览器,自 2015 年 7 月 29 日随新一代 Windows 10 操作系统推出。在结束对旧版 Microsoft Edge 浏览…

机器学习:怎样才能做到从入门到不放弃?

2017年人工智能已经列入了国务院的人工智能发展规划中,人工智能将成为推动中国发展的新生科技力量,并在未来扮演着越来越重要的角色,对于想要从事AI行业的小伙伴们来说,如何能够快速、深入的掌握机器学习相关知识显得尤为重要。下…

最近对kafka的移植工作

Kafka这个linkedin开源的MQ,我在过去的blog简单介绍过。最近3周来,我的工作就是做它的一个Java移植版本,kafka是用scala写的,基于维护和定制的角度,这个拷贝的版本还是用Java。说拷贝,也不尽然,…

有必要服务器虚拟化吗,服务器虚拟化有必要吗

服务器虚拟化有必要吗 内容精选换一换专属云(DeC)专属虚拟化资源池。在专属云内,用户可申请独占物理设备,独享计算和网络资源,并使用可靠的分布式存储。专属虚拟化资源池。在专属云内,用户可申请独占物理设备,独享计算…

Mysql存储过程名规则_sql 存储过程命名规范

规范的命名可以提高开发和维护的效率,如果你正在创建一个新的存储过程,请参考如下的命名规范。句法:存储过程的命名有这个的语法:[proc] [MainTableName] By [FieldName(optional)] [Action][ 1 ] [2] …

C#实用小知识:字符串里的换行

从前,用asp.net core写了一个给客户发交易明细的应用,每天发一次,因为是csv格式,当时用的是StringBuilder来一行一行组装数据,组装完后,EMali或SFTP给客户。后来,为节省服务器资源,需…

多重信号辅助音频分离,让你在嘈杂环境也能指哪听哪儿

在刚刚结束的 I/O 大会的主题演讲中,Google CEO Sundar 提出了机器学习在无障碍(Accessibility)方面的用例:有听觉障碍的人在观看视频时往往需要配合字幕来完成辅助理解,但是如果你遇到了多个人同时在说话,…

线性表的链式实现

用链式实现的线性表,公共接口ADT跟上一篇一样 1,有序链表 成员变量和构造函数: privateLinearNode front;privateintcount;publicLinkedOrderedList(){ front null; count 0;实现清单(将ADT和有序链表扩展的独有操作分别作了注释&…

mysql5.7组复制多主一从搭建_MySql5.7-多源复制(多主单从)

1.1.主库配置my.cnf#确保唯一server-id1#作为Master要开启binloglog-binmysql-bin#binlog format有三种形式:Statement、Mixed、Row,默认设置为mixedbinlog-formatmixed#需要同步的库,不指定默认同步全部库binlog-do-dbradius#不需要同步的库…

EF Core查询标签TagWith

概述在使用EF Core的时候,有时候我们需要追踪它生成的sql语句,那么方法那么多,我们怎么知道对应的sql语句是在代码哪里呢,这时候就需要一个备注,TagWith()能够帮助我们生成对应的注释信息。查询标记有助于将代码中的LI…