登录
首页 >  Golang >  Go问答

nsq 的使用

来源:SegmentFault

时间:2023-02-24 13:43:03 487浏览 收藏

知识点掌握了,还需要不断练习才能熟练运用。下面golang学习网给大家带来一个Golang开发实战,手把手教大家学习《nsq 的使用》,在实现功能的过程中也带大家重新温习相关知识点,温故而知新,回头看看说不定又有不一样的感悟!

问题内容

1.nsq 主要的二个文章。
http://www.infoq.com/cn/news/2015/02/nsq...

http://wiki.jikexueyuan.com/project/nsq-...
。我想问,这个东西做什么用,主要用在什么地方。以前是app开发,不是很了解什么叫消息系统。
求解答 它饿主要用途,能作为实时聊天的服务器么?又或者推送之类的

正确答案

NSQ是一个基于Go语言的分布式实时消息平台.

NSQ 是一个消息平台,主要用来发送消息到订阅者。假设有这样一个场景:用户点击了“确认收货” 按钮。后续可能有以下几个动作需要触发:

  1. 这个商品有送积分的活动,需要送积分给用户;

  2. 这个订单的状态要修改为已经完成;

  3. 这个商品的销量计数要累加;

  4. 这个用户的会员等级可能会按规则发生变化(半年内买够了xx元升级到yy会员);

......可能还有更多

这四个后续行为比较耗时,如果在点击按钮之后依次处理会造成用户体验会很差。我们可以把点击按钮这个事件看作一个消息,下面四个动作看作是这个消息的订阅者。我们需要当消息产生时,自动的通知到所有订阅者。这就是消息平台需要做的最简单的工作。

使用 NSQ 来实现上面的场景:

点击事件会发布( NSQ 的 pulish 操作)一个消息到某个话题( topic 假设名字是 topic_delivery_made)中,你可以按需存数据到这个消息体(payload)中。送积分、用户等级计算、商品销量计算会各自订阅(subscribe)这个话题(topic_delivery_made),当话题中有新的消息时,这四个订阅者都会收到一个消息,消息中包括相同的消息体(payload)。

到这里,我们也就讲完了《nsq 的使用》的内容了。个人认为,基础知识的学习和巩固,是为了更好的将其运用到项目中,欢迎关注golang学习网公众号,带你了解更多关于golang的知识点!

声明:本文转载于:SegmentFault 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>