使用nsqlookupd来推送消息

其实有点儿文不对题,不是使用nsqlookupd来推送的,最终还是使用nsqd来进行推送。

nsq的golang客户端中,consumer实现了从nsqlookupd中动态拉取服务列表,并进行消费,但是producer中没有实现这个,假设有N个nsqd节点,某一个不可用了,那么不就完蛋了?

于是今天自己封装了一个producer,用来实现从nsqlookupd中拉取nsqd列表,并进行消息推送。

nsq是一个分布式的消息队列,nsqd可以自由地进行扩充,灵活性很大,假设线上有一个nsqd挂了,那么可以从nsqlookupd中获取别的可用列表,进行消息推送,这是基本的实现思路。

大概按以下的步骤走:

1.从nsqlookupd的api中获取所有的可用nsqd列表,首先我们的nsqlookupd也必须配置成多台服务器,以免一台不可用的情况下,整个服务都失效的问题。

2.获取了可用的nsqd列表后,遍历服务列表,进行连接,只要有一个连接可用,那么就缓存这个连接,并返回。

3.当进行推送消息的操作的时候,获取可用连接,当推送失败的时候,重新进行第二步来获取连接。

整个逻辑很简单,自己封装了一个:
nsqproducer

共 0 条回复
暂时没有人回复哦,赶紧抢沙发
发表新回复

作者

sryan
today is a good day