从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