【ArchSummit架构师峰会】探讨数据与人工智能相互驱动的关系>>> 了解详情
写点什么

NServiceBus——让创建企业级.NET 系统更加容易

  • 2007-09-18
  • 本文字数:1519 字

    阅读完需:约 5 分钟

NServiceBus 是一个开源的通信框架,它能够帮助开发人员在搭建企业.NET 系统时避免很多典型的常见问题。同时,该框架也提供了一些可伸缩的关键特征,比如对发布 / 订阅的支持、集成的长时间工作流及深入的扩展能力等。据作者说,其本意是为构建分布式应用软件创建一个理想的基础设施。

NServiceBus 在 2006 年一月发行了第一个版本,随后在三月份就在一个大型的分布式系统中得到了应用。为此,InfoQ 特地找到机会和 NServiceBus 的原创者 Udi Dahan 进行了交流。

开发缘由:

开发 NServiceBus 的动力主要有两个。首先,我希望让开发人员在使用异步消息传递机制(无论是否使用 Web Service)时,能够以一种固定的方式编写其服务层。其次,我也希望能够定义一个支持发布 / 订阅语义的通讯 API 模式——这样无论传输接口是否支持发布 / 订阅,程序均可自由地进行移植。当然,避免使用集中的分发模块也非常重要,否则就无法实现良好的可伸缩性。最后,NServiceBus 还为长时间运行的工作流确定了一个确定的形式,并能够与异步消息传递连接起来。

对于使用 SOA 协议构建系统的开发人员来说,基于用 NServiceBus,而不是一些其它的技术或者所谓的“企业服务”框架的理由主要在于:

基于 NServiceBus 开发的系统将很难对其可伸缩性造成负面影响。因为异步消息传递模式的地位非常重要,所以开发人员将在大多数 Web Service 实现中都能潜意识地避免暂时耦合。而使用其它的技术则很难避免这类情况的发生,比如开发人员容易破坏系统的可伸缩型性和易用性——更为致命的是,这类失误只能在程序部署后才能被发现。 NServiceBus 的另一个独到之处就是它将所有的工作流代码完全地从技术实现中独立了出来。这样就让我们很容易地对工作流类做单元测试,进而允许关键业务流程的迭代开发。这些可移植的.NET POJO(Plain Old Java Object)让开发者可以根据实际需要灵活地选择工作流的运行平台。

我们注意到 NServiceBus 将能够配合 MSMQ 使用。之所以这样实现,Udi Dahan 给出了如下说明:

NServiceBus 的核心并不依赖于 MSMQ。NServiceBus 可扩展性允许我们插入自行编写的通信传送器,、订阅存储器和工作流的实现。我已经基于 MSMQ 实现了一个传送器,还有一个则借助了 WCF 的 NetTCP。开发人员既可以使用这些现有组件,也可以根据需要进行自定义。我们知道当前的许多 SOA 产品都与 HTTP 紧密耦合,因此 NServiceBus 的这种实现方式也将是个另辟蹊径的设计。 之所以选择使用 MSMQ,是因为它是微软公司的两大主流的通讯技术之一(另一个是 SQL Server Service Broker)。MSMQ 允许双方在离线的状态下进行通信,且它提供了一整套易于使用的 API,并已经集成到了.NET 框架中,这一点要比 Service Broker 好得多。我个人认为支持离线通信是任何 SOA 基础框架都必须考虑的关键部分——因为 Tenet of Service Autonomy 并不能保证当前通信的另一端处于可用状态。

NServiceBus 是一个开源的产品,基于 Creative Commons Attribution 3.0 License 发布。该框架已经被封装成数个.NET 程序集,允许在任何符合许可协议的应用程序或客户端中使用。

限于采访时间,我们最后则让 Udi 对那些不熟悉 SOA 或者想更多的了解 SOA 实现的读者说说他的想法:

如果你正在开发提供服务这一类型的应用程序,且还不熟悉 SOA 的话,你需要知道 SOA 和你到目前为止所做的事情有很大的区别——你无需再重复地书写类似的代码。与其在使用某项技术遇到困难时步履维艰,不如先花些时间理解高层的消息传递模式,以避免日后的返工。

Udi 在前不久也曾被 DotNetRocks 采访。采访内容包括 SOA 以及 NServiceBus 等。若想了解更多 Udi,你也可以访问他的Blog

查看英文原文: NServiceBus - Makes Building Enterprise .NET Systems Easier

2007-09-18 03:1310361
用户头像

发布了 37 篇内容, 共 82526 次阅读, 收获喜欢 3 次。

关注

评论

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

Linux内核漏洞精准检测如何做?SCA工具不能只在软件层面

华为云开发者联盟

Linux 二进制 漏洞 SCA工具

应用开发专家一席谈:开发低代码,上手低门槛,AppCube使能Citizen Developer,人人都是开发者

华为云开发者联盟

开发者 软件开发 低代码 AppCube 应用开发

一张图彻底搞懂Spring循环依赖

Tom弹架构

Java 架构 Spring Framework

程序员:平安Java岗面试耗尽了我毕生所学,想了想,还是去字节吧

Java 编程 程序员

渗透测试之破解详细演示

网络安全学海

网络安全 信息安全 渗透测试 WEB安全 安全漏洞

一周信创舆情观察(10.18~10.24)

统小信uos

月度发布 | 极狐GitLab14.4版本:禅道集成、预设动态安全扫描DAST和集成错误跟踪功能等新功能上线!

极狐GitLab

律所CRM软件,适用于律师事务所的系统

低代码小观

CRM 管理系统 事务管理 律所 CRM系统

演讲VIDEO大放送|如何打造实景三维高效业务支撑架构

焱融科技

云计算 分布式 GIS 高性能 文件存储

等保办是啥单位?属于哪个系统?有什么作用?

行云管家

网络安全 信息安全 数据安全 等级保护 等保测评

阿里教学篇:一切从代码出发,Spring Boot从入门到源码到项目

Java Spring Cloud Spring Boot

WebRTC(66 - 96)Release Notes

webrtc developer

WebRTC

JSON必知必会【PDF+视频教程】

FunTester

json 教程 视频 接口测试 FunTester

爱奇艺iOS稳定性测试实践

爱奇艺技术产品团队

ios 测试 稳定性

AISWare AntDB 亚信科技数据库产品特性解读——平滑弹性扩展 (二)

亚信AntDB数据库

2021终拿下阿里(P7岗)主动分享:5000字面经总结

编程 程序员 程序人生

云短信服务孰优孰劣?博睿数据9月云短信评测报告

博睿数据

你未必知道的 WebRTC – 前世、今生、未来

FinClip

WebRTC

ffmpeg 推拉流示例

webrtc developer

银行网点业绩增长缓慢,中科柏诚本地生活高效解决

联营汇聚

2021年1-9月墨天轮最受欢迎的20篇技术文章

墨天轮

MySQL 数据库 oracle

倒计时1天|StarRocks Summit 2021,为您揭开数据分析的秘密!

保姆级教程,从概念到实践帮你快速上手 Apache APISIX Ingress

API7.ai 技术团队

云原生 k8s Apache APISIX ingress

微软黑客马拉松@您,低代码风云再赛!

微软商业应用

低代码 Power Platform 黑客马拉松 黑客松

鸿蒙轻内核M核的故障管家:Fault异常处理

华为云开发者联盟

鸿蒙 异常 故障 Fault异常处理 Fault

保障公有云资源安全运维小技巧-使用内网!

行云管家

公有云 内网穿透 内网 云资源 IT运维

客户服务CRM系统,提供优质客户服务

低代码小观

软件 CRM 管理工具 客户服务

精益求精,零代码训练营第五期顺利结业

明道云

20张图!常见分布式理论与解决方案

Java 架构 面试 分布式 后端

netty系列之:netty实现http2中的流控制

程序那些事

Java Netty HTTP 程序那些事 http2

说出来你可能不信,华为技术官珍藏版:SpringBoot全优笔记,限时开源了

Java 程序员 架构 后端 springboot

NServiceBus——让创建企业级.NET系统更加容易_SOA_Robert Bazinet_InfoQ精选文章