MassTransit入门
.NET平台ESB框架的中文资料少的可怜,NServiceBus的有几篇,MassTransit的根本找不到,只好硬着头皮看官方的英文文档,顺便翻译出来加深理解。
欢迎拍砖。
MassTransit是一个.net平台的企业服务总线,使用消息队列(MSMQ,)进行通讯。
安装
1 使用NuGet安装
nuget Install-Package MassTransit
但是要注意:使用NuGet安装的只有dll,不包含MassTransit.RuntimeServices可执行程序和数据库创建脚本。
RuntimeServices通过Subscription Service把消息分发给多个订阅者。
如果你打算使用 UseSubscriptionService,那么就需要自己编译源代码。
2 编译源代码
仓库地址 https://github.com/MassTransit/MassTransit
如果你不想要用vs编译 而是要运行build.bat那么需要下列工具:
- .Net 4.0 sdk
- ruby v 1.8.7
- gems (rake, albacore)
配置
shut up ,just show the code !
public class YourMessage { public string Text { get; set; } }
public class Program
{
public static void Main()
{
Bus.Initialize(sbc =>
{
sbc.UseMsmq(msmq =>
{
msmq.VerifyMsmqConfiguration();
msmq.UseMulticastSubscriptionClient();
//msmq.UseSubscriptionService("123.123.12.12");
});
sbc.ReceiveFrom("msmq://localhost/test_queue");
sbc.Subscribe(subs=>
{
subs.Handler<YourMessage>(msg=>Console.WriteLine(msg.Text));
});
});
Bus.Instance.Publish(new YourMessage{Text = "Hi"});
}
}
这些代码干了些啥事儿呢?
如果我们创建消息系统,首先需要创建消息。上面的代码,我们创建了一个普通的c#类:YourMessage,这就是一个消息,是不是很简单?
上面的代码中,我们使用MassTransit的静态类Bus的静态方法Initialize进行初始化。首先我们告诉MassTransit我们使用MSMQ作为消息传输机(transport)sbc.UseMsmq(...),msmq.VerifyMsmqConfiguration()对MSMQ进行验证。
After that we have the msmq.UseMulticastSubscriptionClient() this tells the bus to pass subscription information around using PGM over MSMQ giving us a way to talk to all of the other bus instances on the network. This eliminates the need for a central control point.
然后sbc.ReceiveFrom("msmq://localhost/test_queue")告诉bus我们收件箱地址(这个地址永远使用本机外网ip,不带“private$”),bus收到消息后会自动分发给所有订阅了这个消息的消费者(consumers )。
最后配置了YourMessage的一个Handler并Publish了一个消息。
如果你觉得Singleton有问题,那可以用下面的代码
var bus = ServiceBusFactory.New(sbc =>
{
sbc.UseMsmq(msmq => msmq.UseMulticastSubscriptionClient());
sbc.ReceiveFrom("msmq://localhost/test_queue");
});
总结:
1,msmq的地址格式:"msmq://42.131.31.22/" + queueName 不带private$
2,如果队列是手工创建的话,需要设置权限。
3,UseSubscriptionService(xxx)如果xxx是远程地址,那么ReceiveFrom(yyy)yyy是本机的外网ip,否则xxx发送不出去响应信息
MassTransit入门的更多相关文章
- MassTransit 入门(一)
本文地址源码 MassTransit是一个面向.net的免费开源分布式应用程序框架. MassTransit使得创建应用程序和服务变得很容易,这些应用程序和服务利用基于消息的.松散耦合的异步通信来获得 ...
- MassTransit RabbitMQ 参考文档
Autofac http://docs.autofac.org/en/latest/lifetime/startup.html RabbitMQ http://www.rabbitmq.com/dot ...
- 译MassTransit 快速入门
给我看代码! 下面是MassTransit的功能设置. public class YourMessage { public string Text { get; set; } } public cla ...
- MassTransit 实现发布/订阅
MassTransit 介绍 先看下masstransit 官网介绍:MassTransit 是一个自由.开源.轻量级的消息总线, 用于使用. NET 框架创建分布式应用程序.MassTransit ...
- Angular2入门系列教程7-HTTP(一)-使用Angular2自带的http进行网络请求
上一篇:Angular2入门系列教程6-路由(二)-使用多层级路由并在在路由中传递复杂参数 感觉这篇不是很好写,因为涉及到网络请求,如果采用真实的网络请求,这个例子大家拿到手估计还要自己写一个web ...
- ABP入门系列(1)——学习Abp框架之实操演练
作为.Net工地搬砖长工一名,一直致力于挖坑(Bug)填坑(Debug),但技术却不见长进.也曾热情于新技术的学习,憧憬过成为技术大拿.从前端到后端,从bootstrap到javascript,从py ...
- Oracle分析函数入门
一.Oracle分析函数入门 分析函数是什么?分析函数是Oracle专门用于解决复杂报表统计需求的功能强大的函数,它可以在数据中进行分组然后计算基于组的某种统计值,并且每一组的每一行都可以返回一个统计 ...
- Angular2入门系列教程6-路由(二)-使用多层级路由并在在路由中传递复杂参数
上一篇:Angular2入门系列教程5-路由(一)-使用简单的路由并在在路由中传递参数 之前介绍了简单的路由以及传参,这篇文章我们将要学习复杂一些的路由以及传递其他附加参数.一个好的路由系统可以使我们 ...
- Angular2入门系列教程5-路由(一)-使用简单的路由并在在路由中传递参数
上一篇:Angular2入门系列教程-服务 上一篇文章我们将Angular2的数据服务分离出来,学习了Angular2的依赖注入,这篇文章我们将要学习Angualr2的路由 为了编写样式方便,我们这篇 ...
随机推荐
- mui 总结
出框框 js内容 mui(".mui-popover").popover('toggle'); 点击“弹出框框”就会弹出这个有class="mui-pop ...
- [Android Pro] 完美解决 No toolchains found in the NDK toolchains folder for ABI with prefix: mips64el-linux-android
原文:https://blog.csdn.net/qq_24118527/article/details/82867864
- Openstack配置文件管理的变迁之路
在管理一个Openstack集群时,如何维护配置文件无疑是其中最艰难和繁琐的任务之一.因为你不仅要面对众多的核心服务(nova,keystone,glance,cinder,etc)的配置文件,还需要 ...
- MySql之修改操作与进阶
一:更新特定行 UPDATE tableName SET 列名 = 值,列名 = 值... WHERE 条件; 二:使用子查询更新数据 UPDATE tableName SET 列名 = SELECT ...
- windows下vbs脚本隐藏控制台
每次想写python代码时,都需要打开IDE进行编写,并且需要创建许多小文件.如果使用jupyter就能够直接书写.但是jupyter需要手动通过控制台打开,这不够方便.通过把jupyter note ...
- Docker(二):Registry 镜像仓库
- [转]oracle 常用的指令
1.显示当前用户名 select user from dual; show user 2.显示当然用户有哪些表 select * from tab; 3.显示当所有用户的表 select * from ...
- SQL SERVER 行列转换(动态)
行转列测试数据: --测试数据 if not object_id(N'Tempdb..#T') is null drop table #T Go Create table #T([Name] nvar ...
- Shell脚本编程(二):shell变量
定义变量 定义变量时,变量名不加美元符号($,PHP语言中变量需要),如: your_name="runoob.com" 注意,变量名和等号之间不能有空格,这可能和你熟悉的所有编程 ...
- Socket网络编程--简单Web服务器(4)
上一小节已经实现了对图片的传输,接下来就是判断文件是否为js,css,png等格式.我们增加一个函数用于判断格式 int WebServer::get_filetype(char *type,char ...