写点什么

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:1310810
用户头像

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

关注

评论

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

定制+轻量级低代码:满足客户个性需求的最佳实践

天津汇柏科技有限公司

低代码 软件定制开发 软件开发定制

WorkPlus移动应用管理平台,助力企业实现高效移动办公

BeeWorks

《Hive编程指南》读书笔记

京东科技开发者

三个方面浅析数据对大语言模型的影响

华为云开发者联盟

人工智能 华为云 华为云开发者联盟 大语言模型

万字图解 | 深入揭秘IP层工作原理

云舒编程

IP MTU 路由表 子网划分 图解网络

foobar2000 for mac多功能音频播放器 v2.6.1免激活版

Rose

mac音乐播放器 foobar2000中文版 foobar2000破解版

得物从零构建亿级消息推送系统的送达稳定性监控体系技术实践

JackJiang

网络编程 即时通讯 IM

当当网按关键字搜索dangdang商品 API (item_search-按关键字搜索dangdang商品-dangdang.item_search)在电商中的应用

技术冰糖葫芦

API

Mac游戏星露谷物语 - 创造梦想中的田园生活

Rose

苹果电脑 模拟经营游戏 星露谷物语游戏下载 macos游戏推荐

万字图解|深入揭秘 (数据链路层、物理层) 工作原理

云舒编程

IP 物理层 路由 图解网络 数据链路层

NineData和Klustron完成产品兼容互认证

NineData

数据库 数据管理 NineData Klustron 泽拓昆仑

大规模集群下,如何快速实现无死角网络连通性的主动巡检

ii2day

云原生 压力测试 Cloud Native kubernetes 运维 自动巡检

WorkPlus构建便捷高效的企业移动门户平台

BeeWorks

苹果电脑游戏:以撒的结合:重生+忏悔+胞衣 Mac中文版下载

Rose

mac游戏 以撒的结合:忏悔

阿里云 Flink 原理分析与应用:深入探索 MongoDB Schema Inference

Apache Flink

想在 Mac 里装 Windows ?试试 Parallels Desktop虚拟机!

Rose

Windows系统 Mac双系统安装 Parallels Desktop

【技术探讨】如何选择一款距离远的无线通信模块?

Geek_ab1536

探讨 LLM 的潜在风险 (偏见与毒性等),是否存在解决之道?

Baihai IDP

人工智能 程序员 AI LLM 白海科技

WorkPlus Meet私有化视频会议内网部署

BeeWorks

马斯克接手Twitter一年后的成果-工作量化的重要性

云舒编程

twitter 马斯克 推特

非常火爆“太空种田”游戏Slipways mac破解版

Rose

mac游戏 苹果电脑游戏推荐

测试管理 | 入班第二个月后拿到4个知名企业Offer,他是怎么做到的?

测吧(北京)科技有限公司

测试

QSpace Pro 一款简洁高效的多窗格文件管理器,灵活且实用!

Rose

Mac软件 QSpace 多窗格文件管理器

火山引擎VeDI:新增微信小程序广告A/B实验功能,助力企业降低获客成本

字节跳动数据平台

数据库 大数据 ab测试 企业号 1 月 PK 榜 对比实验

Axure RP 8使用技巧分享 含axure rp8汉化授权码

Rose

axure rp9下载 Axure RP 8汉化包 Axure破解版 Axure使用教程

bean的一生

京东科技开发者

用游戏盾会掉线吗,游戏出现掉线或者卡顿的可能有哪些原因

德迅云安全杨德俊

苹果macos效率神器alfred5新功能介绍 及alfred 5汉化包下载

Rose

mac软件下载 Alfred 5破解版 Alfred 中文 Mac效率办公软件

SnapGene 5最新补丁版 生物分子学软件snapgene5 for Mac安装教程

Rose

Mac软件 SnapGene 5破解版 SnapGene 5下载 DNA序列分析

NLP国内外大模型汇总列表[文心一言、智谱、百川、星火、通义千问、盘古等等]

汀丶人工智能

nlp 大模型

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