golang 中操作nsq队列数据库

简介: 首先先在本地将服务跑起来,我用的是docker-compose ,一句话6666 先新建一个docker-compose.yml version: '2' services: nsqlookupd: image: nsqio/nsq command: /nsqlookupd ports: - "192.

首先先在本地将服务跑起来,我用的是docker-compose ,一句话6666

先新建一个docker-compose.yml
version: '2'
services:
  nsqlookupd:
    image: nsqio/nsq
    command: /nsqlookupd
    ports:
      - "192.168.9.111:4160:4160"
      - "192.168.9.111:4161:4161"
  nsqd:
    image: nsqio/nsq
    command: /nsqd --lookupd-tcp-address=nsqlookupd:4160
    depends_on:
      - nsqlookupd
    ports:
      - "192.168.9.111:4150:4150"
      - "192.168.9.111:4151:4151"
  nsqadmin:
    image: nsqio/nsq
    command: /nsqadmin --lookupd-http-address=nsqlookupd:4161
    depends_on:
      - nsqlookupd
    ports:
      - "192.168.9.111:4171:4171"

  然后整个数据就跑起来了

写个生产消息的

tproducter.go

package main
import(
    "log"
    "github.com/nsqio/go-nsq"
    "encoding/json"
    "strconv"
)

type Person struct {
    Id int
    Name string
    Age int
    NickName string
}

func main() {
    config :=nsq.NewConfig()
    w,err :=nsq.NewProducer("192.168.9.111:4150",config)
    if err !=nil {
        log.Panic("Could not create producer.")
    }
    defer w.Stop()
    for i :=0;i<100;i++{
        p :=&Person{}
        p.Id = i
        p.Name = "Jack"+strconv.Itoa(i)
        p.NickName="Luo"+strconv.Itoa(i)
        p.Age = i
        info,jerr :=json.Marshal(p)
        err :=w.Publish("write_test",info)
        if err !=nil || jerr !=nil {
            log.Panic("Could not connect.")
        }
    }
    w.Stop()
}

再写个消费的

tconsumer.go

package main

import (
    "log"
    "github.com/nsqio/go-nsq"
    "time"
)

func main() {
    config :=nsq.NewConfig()
    q,err := nsq.NewConsumer("write_test","ch",config)
    if err !=nil{
        log.Panic("Could not create consumer.")
    }
    defer q.Stop()
    q.AddHandler(nsq.HandlerFunc(func(message *nsq.Message) error{
        log.Printf("Got a message: %v",string(message.Body))
        time.Sleep(5*time.Second)
        return nil
    }))
    //err = q.ConnectToNSQD("192.168.9.111:32771");
    err = q.ConnectToNSQD("192.168.9.111:4150");
    if err !=nil {
        log.Panic("Could not connect")
    }
    time.Sleep(3600*time.Second)
}

然后就要以6起来了

/usr/local/go/bin/go run /Users/jackluo/Works/golang/src/nsq/tconsumer.go
2017/08/29 15:29:45 INF    1 [write_test/ch] (192.168.9.111:4150) connecting to nsqd
2017/08/29 15:29:45 Got a message: {"Id":0,"Name":"Jack0","Age":0,"NickName":"Luo0"}
2017/08/29 15:29:50 Got a message: {"Id":1,"Name":"Jack1","Age":1,"NickName":"Luo1"}
2017/08/29 15:29:55 Got a message: {"Id":2,"Name":"Jack2","Age":2,"NickName":"Luo2"}
2017/08/29 15:30:00 Got a message: {"Id":3,"Name":"Jack3","Age":3,"NickName":"Luo3"}
2017/08/29 15:30:05 Got a message: {"Id":4,"Name":"Jack4","Age":4,"NickName":"Luo4"}
2017/08/29 15:30:10 Got a message: {"Id":5,"Name":"Jack5","Age":5,"NickName":"Luo5"}
2017/08/29 15:30:15 Got a message: {"Id":6,"Name":"Jack6","Age":6,"NickName":"Luo6"}
2017/08/29 15:30:20 Got a message: {"Id":7,"Name":"Jack7","Age":7,"NickName":"Luo7"}
2017/08/29 15:30:25 Got a message: {"Id":8,"Name":"Jack8","Age":8,"NickName":"Luo8"}
2017/08/29 15:30:30 Got a message: {"Id":9,"Name":"Jack9","Age":9,"NickName":"Luo9"}
2017/08/29 15:30:35 Got a message: {"Id":10,"Name":"Jack10","Age":10,"NickName":"Luo10"}
2017/08/29 15:30:40 Got a message: {"Id":11,"Name":"Jack11","Age":11,"NickName":"Luo11"}
2017/08/29 15:30:45 Got a message: {"Id":12,"Name":"Jack12","Age":12,"NickName":"Luo12"}

可以通过这个地址看得到界面http://192.168.9.111:4171/counter

目录
相关文章
|
28天前
|
SQL 数据库连接 数据库
你不知道ADo.Net中操作数据库的步骤【超详细整理】
你不知道ADo.Net中操作数据库的步骤【超详细整理】
16 0
|
3月前
|
SQL 关系型数据库 MySQL
MySQL| 数据库的管理和操作【操作数据库和操作表】【附练习】
MySQL | 数据库的基本操作和表的基本操作【附练习】
|
3月前
|
SQL Java 数据库连接
java链接hive数据库实现增删改查操作
java链接hive数据库实现增删改查操作
146 0
|
3月前
|
SQL 关系型数据库 MySQL
MySQL | 数据库的管理和操作【表的增删改查】(一)
MySQL | 数据库的管理和操作【表的增删改查】
|
3月前
|
SQL 关系型数据库 MySQL
MySQL | 数据库的管理和操作【表的增删改查】(二)
MySQL | 数据库的管理和操作【表的增删改查】(二)
|
2天前
|
SQL JavaScript API
❤Nodejs 第四章(操作本地数据库实现删除-源码地址已开放)
【4月更文挑战第4天】❤Nodejs 第四章(操作本地数据库实现删除-源码地址已开放)在Node.js中实现删除本地数据库记录的操作。首先尝试通过SQL删除ID为8的用户,然后编写`app.delete`路由处理程序,从请求体获取ID并执行删除。。最终成功删除用户并展示了数据库的更新结果。下一节将优化增删改查功能。
15 1
|
1月前
|
缓存 NoSQL 数据库
[Redis]——数据一致性,先操作数据库,还是先更新缓存?
[Redis]——数据一致性,先操作数据库,还是先更新缓存?
|
1月前
|
SQL 存储 关系型数据库
【mysql】—— 数据库的操作
【mysql】—— 数据库的操作
【mysql】—— 数据库的操作
|
2月前
|
存储 SQL 数据库连接
连接并操作数据库:Python 数据库案例
数据库是一种用于存储和管理数据的工具,它以一种有组织的方式将数据存储在文件或内存中,以便于检索和处理。数据库系统通常使用 SQL(Structured Query Language)语言来进行数据的操作,包括数据的插入、查询、更新和删除等。
|
2月前
|
前端开发 数据库连接 数据库
ASP.NETMVC数据库完整CRUD操作示例
ASP.NETMVC数据库完整CRUD操作示例
29 0