- 1、本文档共15页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
参考资料--mastransit探究初步繁体
MassTransit 探究初步
1.??背景
作为SOA基礎設施,企業服務總線(ESB)是一個具有高分布性、事件驅動服務的SOA架構,是當前企業集成的主流框架。
2.??簡介
網站://
?
MassTransit (MT) is a framework forcreating distributed applications on the .Net platform. MT provides the abilityto subscribe to messages by type and then connect different processing nodesthough message subscriptions building a cohesive mesh of services.
?
主要特性:
l? Bus architecture
l? Sagas
l? Exception management
l? Transactions
l? Serialization
l? Headers
l? Consumer lifecycle
l? Built on top of Rabbit Mq
l? IOC support
?
授權:
基於Apache 2.0,可以使用在任何環境中。
3.??架構
MassTransit在消息隊列(MQ)之上構建了消息總線機制,封裝了對消息隊列的操作,以及其它的組件,比如序列化、日志、Saga、持久化等。
?
下圖为傳入消息處理管道模型:
?
4.??整體分析
MassTransit的目標是作为消息機制的抽象框架,因此,它本身並不具體實現MQ,而是通過集成其它MQ產品來作为其通信層。目前官方已集成的MQ產品有MSMQ、RabbitMQ。其它非官方補充了ActiveMQ。
MassTransit在MQ之上添加了Sagas、多線程、異常處理、事務、序列化、消息頭(Header)、消息使用者生命周期管理、路由、Rx(Reactive Extension 反應式擴展)集成、NHibernate集成、調試、跟蹤、日志輸出、加密、定時服務等。
5.??特性分析
5.1.? 聲明式配置
MassTransit本身使用了許多優秀的設計,比如對MSMQ、RabbitMQ的使用,通過在Bus構造配置中調用UseMSMQ()或UseRabbitMQ()來聲明式的决定。
5.2.? 通過擴展方法隱藏具體實現
通過分析源碼,可以發現UseXXX函數是通過定義在MassTransit.Transports.MSMQ.dll和MassTransit.Transports.RabbitMq.dll中的擴展方法實現的,這样當用戶引用相應的DLL時,方法調用才會開放给用戶。即用戶選擇具體使用哪種Transport時,是通過引用相應的DLL來决定的。DLL引用入項目後,具體MQ產品特定的配置,函數等方法也附加到了基類對象中。這样可以避免在基類中定義大量子類特定接口
MassTransit所有擴展組件均是采用這種方法,比如日志(Logging)組件。
6.??入門
首先需要定義消息:
public class YourMessage { public string Text { get; set; } }
消息總線的創建可以通過Bus類靜態方法Initialize進行,傳入相應的配置方法,如下所示:
?
Bus.Initialize(sbc =
{
sbc.UseMsmq();
sbc.VerifyMsmqConfiguration();
sbc.UseMulticastSubscriptionClient();
sbc.ReceiveFrom(msmq://localhost/test);
sbc.Subscribe(subs =
{
subs.HandlerYourMessage(msg = Console.WriteLine(From bus 1: + msg.Text));
});
});
初始化好Bus之後,就可以調用Publish方法發布消息了:
Bus.Instance.Publish(new YourMessage { Text = Hi });
在初始化中,通過sbc.Subscribe函數注冊了一個Handler,其作用是在控制台中輸出消息文本。
創建一個控制台應用程序,在main函數中完成初始化和發布,可以在隨後的輸出中看到消息文本。
7.??高級功能使用
7.1.? Subscription Service
参考:?//en/latest/overview/subscriptions.html
?
如果使用的消息隊列不提供訂閱
您可能关注的文档
- 医学ppt--经周导入中心静脉置管.ppt
- 医学ppt--经外科补液特殊性.ppt
- 医学ppt--耐氧西林金黄色葡萄球菌相关知识.ppt
- 医学ppt--肥胖心血管疾病.ppt
- 医学ppt--胸外科常见疾的诊治——一自发性气胸.ppt
- 医学ppt--胸心脏按压术操.ppt
- 医学ppt--胸腔闭式引流护理的护理.ppt
- 医学ppt--胸诊治专家共识.ppt
- 医学ppt--胸部损伤和脓胸人的护理.ppt
- 医学ppt--脏解剖及生理9.ppt
- 五位一体教案教学教案设计.docx
- 思修与法基-教学教案分享.pptx
- 大学军事之《中国国防》题库分享.docx
- 2023版毛泽东思想和中国特色社会主义理论体系概论第五章-中国特色社会主义理论体系的形成发展.pdf
- 思修与法基 教学全案分享.docx
- 大学军事之《军事思想》题库分享.docx
- 《经济思想史》全套课件-国家级精品课程教案课件讲义分享.pdf
- 厦门大学国际金融全套资料(国家级精品课程)--全套课件.pdf
- 2023版毛泽东思想和中国特色社会主义理论体系概论第五章-中国特色社会主义理论体系的形成发展.docx
- 2023版毛泽东思想和中国特色社会主义理论体系概论第五章中国特色社会主义理论体系的形成发展分享.pdf
文档评论(0)