从GitHub项目发布页,下载最新的发布版本。
Shuttle-ESB源码包列表:http://www.nuget.org/packages?q=shuttle-esb
发布页面:https://github.com/Shuttle/shutle-esb/releases
因为Shuttle ESB需要队列来操作,所以我们使用微软的MSMQ来实现。在做实例前,必须先确保你电脑上安装了MSMQ。
安装MSMQ:http://msdn.microsoft.com/en-us/library/aa967729%28v=vs.110%29.aspx
我们来创建一个非常简单的实例。我们发送一个命令,到主机服务器,服务器接收并显示。
注意:确保所有项目(源代码以及你所新建的项目)在同一版本的Framework下(如都在FrameWork 4.0下),用以保证IHost类型的服务都能够正常运行。
建立一个VS解决方案并创建一个新的空方案。
首先点击创建新项目;
在其他项目类型选择Visual Studio解决方案并单击“空白解决方案模板;
给解决方案起名为:QuickStart.Shuttle;
点击OK完成创建。
因为我们的消息是共享的,所以创建一个单独的组件共享控制。新建一个项目,命名为:QuickStart.Shuttle.Messages.
新建一个名为WriteBlueMessageCommand 的类,并编写如下代码:
namespace QuickStart.Shuttle.Messages { public class WriteBlueMessageCommand { public string BlueMessage { get; set; } } }
新建一个控制台应用程序,命名为:QuickStart.Shuttle.Client ,并添加引用:
QuickStart.Shuttle.Messages(项目引用)
Shuttle-esb-msmq(可以下载源代码)
在控制台应用实现中添加如下代码:
using System; using QuickStart.Shuttle.Messages; using Shuttle.Core.Infrastructure; using Shuttle.ESB.Core; namespace QuickStart.Shuttle.Client { internal class Program { private static void Main(string[] args) { var bus = ServiceBus.Create().Start(); ColoredConsole.WriteLine( ConsoleColor.DarkGray, "(to exit press enter on an empty line):"); ColoredConsole.WriteLine( ConsoleColor.DarkGray, "Enter a message to write in blue on the server and press enter:"); Console.WriteLine(); var message = Console.ReadLine(); while (!string.IsNullOrEmpty(message)) { bus.Send(new WriteBlueMessageCommand { BlueMessage = message }); message = Console.ReadLine(); } bus.Dispose(); } } }
Shuttle ESB需要知道消息往哪发。由于我们使用的是默认的消息路由的供应商,我们需要在应用程序配置文件中定义的路径。在项目配置中添加一条路径:
<?xml version="1.0"?> <configuration> <configSections> <section name="serviceBus" type="Shuttle.ESB.Core.ServiceBusSection, Shuttle.ESB.Core"/> </configSections> <serviceBus> <messageRoutes> <messageRoute uri="msmq://./quickstart_server_inbox_work"> <add specification="StartsWith" value="QuickStart"/> </messageRoute> </messageRoutes> </serviceBus> </configuration>
它的作用就是,告诉Shuttle ESB发送所有的消息。起点是QuickStart,终点是 msmq://./quickstartserverinbox_work
新建一个项目QuickStart.Shuttle.Server ,并添加如下引用:
QuickStart.Shuttle.Messages(项目引用)
Shuttle-esb-msmq(源代码文件)
新建一个类,名为ServiceBusHost,因为我们将使用通用的主机托管服务器,所以我们需要一个通用的主入口点。它通过实现IHost接口,去找到所需执行的类。所以我们的ServiceBusHost类需要实现IHost接口。
using System; using Shuttle.Core.Host; using Shuttle.ESB.Core; namespace QuickStart.Shuttle.Server { public class ServiceBusHost : IHost, IDisposable { private static IServiceBus bus; public void Start() { bus = ServiceBus.Create().Start(); } public void Dispose() { bus.Dispose(); } } }
我们的服务总线实例,需要处理一个输入队列,我们在配置文件中进行配置:
<?xml version="1.0"?> <configuration> <configSections> <section name="serviceBus" type="Shuttle.ESB.Core.ServiceBusSection, Shuttle.ESB.Core"/> </configSections> <serviceBus> <inbox workQueueUri="msmq://./quickstart_server_inbox_work" errorQueueUri="msmq://./quickstart_server_inbox_error"/> </serviceBus> </configuration>
为了终端能够高效的启动,我们需要进行一些配置。建立你的服务器项目的本地引用的程序集复制。打开项目属性,然后点开 调试 选项卡,在启动类型中,选择 启动外部程序。 然后选择本项目的bin目录下的Shuttle.Core.Host.exe 作为启动项目(因为引用了,所以会出现在这里。似乎是废话~~)
对于Shuttle ESB的消息接受机制,我们要为每一个消息类型创建一个处理程序(Handler)。我们来为WriteBlueMessageCommand 消息创建一个Handler。新建一个名为WriteBlueMessageHandler 的类,并继承IMessageHandler 接口。
using System; using QuickStart.Shuttle.Messages; using Shuttle.Core.Infrastructure; using Shuttle.ESB.Core; namespace QuickStart.Shuttle.Server { public class WriteBlueMessageHandler : IMessageHandler<WriteBlueMessageCommand> { public void ProcessMessage(HandlerContext<WriteBlueMessageCommand> context) { ColoredConsole.WriteLine(ConsoleColor.Blue, context.Message.BlueMessage); } public bool IsReusable { get { return true; } } } }
为了能够正常运行解决方案,需要做如下配置:右击解决方案,选择启动项目选项卡,然后选择多启动项目之后,选择Client和Server。
然后,你就可以运行并测试了。
你已经创建了一个基于ESB的一个非常简单的实例,但是这个例子是比较简陋的。从这里你可以了解样品并与社区参与扩大你的范围。
实例下载:http://download.csdn.net/detail/liu765023051/7754559
原文地址:http://shuttle.github.io/shuttle-esb/getting-started/index.html