go-nsq使用简述

一 环境依赖:

  golang 开发环境(version >= 1.2) 下源码,配置环境变量,执行安装脚本

  gpm 依赖包管理器 ubantu: sudo apt-get intall gpm

二 NSQ安装:

  1. git获取源码: mkdir -p $GOPATH/src/github.com/nsqio;cd $GOPATH/src/github.com/nsqio;git clone https://github.com/nsqio/nsq.git;cd nsq
  2. 安装依赖包: gpm install
  3. 安装NSQ: go install ./...

三 开启NSQ:

  1. nsqd节点维护进程:nsqlookupd &
  2. nsqd节点进程:nsqd --lookupd-tcp-address=127.0.0.1:4160 &
  3. 消息产看进程:nsqadmin --lookupd-http-address=127.0.0.1:4161 &

ps:nsqlookupd与nsqadmin为辅助进程,可不使用直接用nsqd也可正常工作.

这里开启的进程均用默认的端口

四 工具测试:

  • curl -d 'hello world 1' 'http://127.0.0.1:4151/put?topic=test' // 产生一个topic为“test” 消息内容为“hello world”的消息
  • nsq_to_file --topic=test --output-dir=./tmp --lookupd-http-address=127.0.0.1:4161 // 将topic为“test”的消息写到./tmp目录下的一个文件中

五 代码测试:

package main

import (

"fmt"

"time"

"github.com/nsqio/go-nsq"

)

// nsq发布消息

func Producer() {

p, err := nsq.NewProducer("127.0.0.1:4150", nsq.NewConfig()) // 新建生产者

if err != nil {

panic(err)

}

if err := p.Publish("test", []byte("hello NSQ!!!")); err != nil { // 发布消息

panic(err)

}

}

// nsq订阅消息

type ConsumerT struct{}

func (*ConsumerT) HandleMessage(msg *nsq.Message) error {

fmt.Println(string(msg.Body))

return nil

}

func Consumer() {

c, err := nsq.NewConsumer("test", "test-channel", nsq.NewConfig()) // 新建一个消费者

if err != nil {

panic(err)

}

c.AddHandler(&ConsumerT{}) // 添加消息处理

if err := c.ConnectToNSQD("127.0.0.1:4150"); err != nil { // 建立连接

panic(err)

}

}

// 主函数

func main() {

Producer()

Consumer()

time.Sleep(time.Second * 3)

}

// 运行将会打印: hello NSQ!!!

六 使用总结:

  单机使用条件,同步发布消息速度也非常快(10w/s),发布消息端基本无需再做缓存封装。接收端的消息处理应耗时尽量的短,避免消息积累,当消息积累到NSQ的缓存的数量会将多余的消息写到文件,此时也会减缓发送端的发送速度,

  因此,对接收端可使用channel和go routine做简单封装处理。若某topic消息产生太快太多也可将其单独使用一个nsqd处理,避免消息积累影响其它消息投递与接收。

原文发布于微信公众号 - Golang语言社区(Golangweb)

原文发表时间:2017-04-25

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏听Allen瞎扯淡

解决mac升级10.11后,出现的 xcrun: error: invalid active developer path, missing xcrun 错误

前天把小mac升级到了10.11,结果今天在终端里使用git的时候,弹出一行莫名其妙的错误:xcrun: error: invalid active devel...

700
来自专栏程序员同行者

14-使用glusterfs做持久化存储

1462
来自专栏散尽浮华

Centos6.X 下安装并使用VNC的操作记录

VNC是一个的"远程桌面"工具。,通常用于“图形界面”的方式登录服务器,可视化操作。废话不多说了,操作记录如下: 1)安装桌面环境 [root@vm01 ~]#...

3377
来自专栏Felix的技术分享

Stetho的通信原理

2873
来自专栏Java编程技术

UML建模(组件图)

组件图是为了展示组元(components),组元提供的接口(provided inerfaces)和需要调用的接口(required interfaces),...

3842
来自专栏主机笔记

笔记本电脑安装linux桌面版

手里一个旧的笔记本配置比较低,装windows很卡,于是就决定装一个windows,今天记录下笔记本安装ubuntu桌面版的过程,主要2件事,做系统盘和装系统,...

1.5K7
来自专栏何俊林

手把手图文并茂教你用Android Studio编译FFmpeg库并移植

之前曾写过一篇《FFmpeg在Linux下安装编译过程》,今天有空就用Android Studio编译FFmpeg库并移植,并附上调用ffmpeg简单示例,看下...

3676
来自专栏PaddlePaddle

速问速答|想在Windows环境中快速安装PaddlePaddle,还需解决哪些问题?

PaddlePaddle近期新上线的Windows快速安装包,已经有很多小伙伴跑来体验

1566
来自专栏散尽浮华

Centos 6.9下部署Oracle 11G数据库环境的操作记录

操作系统:Centos6.9(64Bit) Oracle:11g 、11.2.0.4.0版本 Ip地址:172.16.220.139 废话不多说了,下面记录安装...

2509
来自专栏一个默默无闻的工程师的日常

OpenStack Queens Cinder Multi-Attach 功能

2754

扫码关注云+社区