代码拉取完成,页面将自动刷新
package source
import (
streams "gitee.com/qw_1215/glink"
"gitee.com/qw_1215/glink/flow"
"github.com/nsqio/go-nsq"
"time"
)
type NsqSource struct {
consumer *nsq.Consumer
url string
out chan interface{}
}
func NewNsqSource(url string, topic string, channel string) (*NsqSource, error) {
cfg := nsq.NewConfig()
cfg.LookupdPollInterval = time.Second //设置重连时间
c, err := nsq.NewConsumer(topic, channel, cfg) // 新建一个消费者
sq := &NsqSource{
consumer: c,
url: url,
out: make(chan interface{}),
}
streams.Check(err)
go sq.init()
return sq, nil
}
func (rs *NsqSource) init() error {
rs.consumer.SetLogger(nil, 0) //屏蔽系统日志
rs.consumer.AddHandler(rs)
// 建立一个nsqd连接
if err := rs.consumer.ConnectToNSQD(rs.url); err != nil {
return err
}
return nil
}
//处理消息
func (rs *NsqSource) HandleMessage(msg *nsq.Message) error {
rs.out <- msg
return nil
}
// Via streams data through given flow
func (rs *NsqSource) Via(_flow streams.Flow) streams.Flow {
flow.DoStream(rs, _flow)
return _flow
}
// Out returns channel for sending data
func (rs *NsqSource) Out() <-chan interface{} {
return rs.out
}
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。