内容简介:我们都会有从异步队列中消费的需求,今天来说下gobox中的consumer处理框架定义每条消息
我们都会有从异步队列中消费的需求,今天来说下gobox中的consumer处理框架
consumer处理架构图
重要的对象
IMessage
定义每条消息
type IMessage interface { Body() []byte }
ConsumerHandleFunc
consumer中从队列收到每条消息后,调用这个方法
type ConsumerHandleFunc func(message IMessage) error
IConsumer
定义消费者行为
type IConsumer interface { SetHandleFunc(hf ConsumerHandleFunc) Start() Stop() }
NewWorkerFunc
每个Worker的构造方法
type NewWorkerFunc func() IWorker
IWorker
定义Worker
type IWorker interface { SetWorkId(id int) SetLogger(logger golog.ILogger) Work(wg *sync.WaitGroup, lineCh chan []byte, stopCh chan bool) }
LineProcessFunc
每条消息在Worker中的实际处理方法
type LineProcessFunc func(line []byte) error
BaseWorker
框架提供的一个简单基础Worker对象,组合这个对象后,只需要实现 LineProcessFunc
即可
type BaseWorker struct
Task
Task用于实现consumer的处理框架
使用示例
package main import ( "github.com/goinbox/goconsumer" "fmt" "strconv" "time" ) // 这里实现Worker type DemoWorker struct { *goconsumer.BaseWorker } func NewDemoWorker() goconsumer.IWorker { worker := &DemoWorker{goconsumer.NewBaseWorker()} worker.SetLineProcessFunc(worker.LineProcessFunc) return worker } func (d *DemoWorker) LineProcessFunc(line []byte) error { idStr := strconv.Itoa(d.Id) fmt.Println("wid:" + idStr + " process line:" + string(line)) return nil } // 这里实现Message type DemoMessage struct { body []byte } func (d *DemoMessage) Body() []byte { return d.body } // 这里实现一个简单的Consumer,模拟从队列中获得100条消息 type DemoConsumer struct { hf goconsumer.ConsumerHandleFunc } func (d *DemoConsumer) SetHandleFunc(hf goconsumer.ConsumerHandleFunc) { d.hf = hf } func (d *DemoConsumer) Start() { for i := 0; i < 100; i++ { str := "This message is from DemoConsumer loop " + strconv.Itoa(i) d.hf(&DemoMessage{[]byte(str)}) } time.Sleep(time.Second * 1) } func (d *DemoConsumer) Stop() { } // 执行Task任务,调用consumer处理框架 func main() { task := goconsumer.NewTask("Demo") consumer := new(DemoConsumer) task.SetConsumer(consumer). SetWorker(10, NewDemoWorker). Start() }
欢迎大家使用,使用中有遇到问题随时反馈,我们会尽快响应,谢谢!
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网
猜你喜欢:- 简述大数据实时处理框架
- 流式处理框架storm浅析(上篇)
- Bootstrap开发框架界面的调整处理
- iOS换肤功能的简单处理框架
- 一个不错的音视频快速处理框架
- Apache Flink 1.9.3 发布,流处理框架
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
数据科学家养成手册
高扬 / 电子工业出版社 / 2017-5 / 79
作为认知科学的延伸,数据科学一方面应该越来越引起广大大数据工作者的重视,另一方面也要撩开自己的神秘面纱,以最为亲民的姿态和每位大数据工作者成为亲密无间的战友,为用科学的思维方式进行工作做好理论准备。《数据科学家养成手册》从众多先贤及科学家的轶事讲起,以逐步归纳和递进的脉络总结出科学及数据科学所应关注的要点,然后在生产的各个环节中对这些要点逐一进行讨论与落实,从更高、更广的视角回看科学及数据科学在各......一起来看看 《数据科学家养成手册》 这本书的介绍吧!