easynetq发布订阅demo实现注意事项

最近开始在项目中使用easynetq,大概了解了下api,在网上看了下示例,结果没有一个运行成功的,一个最简单的发布订阅都没有成功。我是直接运行起来别人的示例,不应该啊,后来一直分析一直分析,最后发现:消息没有序列化!这还是其一,第二点,应该要先起来消息接收端,再起来消息发布端。一开始就是简单的:

static void Main()
{
using( var bus = RabbitHutch.CreateBus( "host=localhost" ) )
{
bus.Subscribe<TextMessage>( "test", HandleTextMessage ); Console.WriteLine( "Listening for messages. Hit <return> to quit." );
Console.ReadLine();
}
} static void HandleTextMessage( TextMessage textMessage )
{
Console.ForegroundColor = ConsoleColor.Red;
Console.WriteLine( $"Got message {textMessage.Text}" );
}
private static void Main()
{
using (var bus = RabbitHutch.CreateBus("host=localhost"))
{
var input = "";
Console.WriteLine("Enter a message. 'Quit' to quit.");
while ((input = Console.ReadLine())?.ToUpper() != "QUIT")
{
bus.Publish(new TextMessage { Text = input });
}
}
}
public class TextMessage
{
public string Text { get; set; }
}

结果,黑窗口还是黑窗口,为什么没有消息订阅的输出?其实就是因为我们的消息没有序列化。在发布端增加:

bus.Publish<string>(JsonConvert.SerializeObject(new TextMessage{ Text = "Hello World" }));

在接口端增加:

var myMessage = (TextMessage)JsonConvert.DeserializeObject<TextMessage>(obj);

这样就可以了。

其实我们可以使用高级API中的message类来包装我们的消息,这样的话,可以不用在发布端序列化消息,但是依旧需要在接收端反序列化消息。具体请参考:
EasyNetQ-高级API

https://github.com/aspnet/PlatformAbstractions/blob/release/1.1/src/Microsoft.Extensions.PlatformAbstractions/PlatformServices.cs

上一篇:C#进阶系列——DDD领域驱动设计初探(一):聚合


下一篇:C#进阶系列——MEF实现设计上的“松耦合”(四):构造函数注入