easynetq发布订阅demo实现注意事项
程序员文章站
2022-04-08 17:45:47
最近开始在项目中使用easynetq,大概了解了下api,在网上看了下示例,结果没有一个运行成功的,一个最简单的发布订阅都没有成功。我是直接运行起来别人的示例,不应该啊,后来一直分析一直分析,最后发现:消息没有序列化!这还是其一,第二点,应该要先起来消息接收端,再起来消息发布端。一开始就是简单的: ......
最近开始在项目中使用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