内容简介:OpenMix 出品:https://openmix.org Mix XWP 通用的工作池 A common worker pool Installation go get github.com/mix-go/xwp Usage 先创建一个结构体用来处理任务,使用类型断言转换任务数据类型,例如:i :...
OpenMix 出品:https://openmix.org
Mix XWP
通用的工作池
A common worker pool
Installation
go get github.com/mix-go/xwp
Usage
先创建一个结构体用来处理任务,使用类型断言转换任务数据类型,例如:i := data.(int)
type Foo struct { } func (t *Foo) Do(data interface{}) { // do something }
调度任务
- 也可以使用
RunF采用闭包来处理任务 - 如果不想阻塞执行,可以使用
p.Start()启动
jobQueue := make(chan interface{}, 200) p := &xwp.WorkerPool{ JobQueue: jobQueue, MaxWorkers: 1000, InitWorkers: 100, MaxIdleWorkers: 100, RunI: &Foo{}, } go func() { // 投放任务 for i := 0; i < 10000; i++ { jobQueue <- i } // 投放完停止调度 p.Stop() }() p.Run() // 阻塞等待
异常处理:Do 方法中执行的代码,可能会出现 panic 异常,我们可以通过 recover 获取异常信息记录到日志或者执行其他处理
func (t *Foo) Do(data interface{}) { defer func() { if err := recover(); err != nil { // handle error } }() // do something }
查看 Workers 的执行状态:通常可以使用一个定时器,定时打印或者告警处理
go func() { ticker := time.NewTicker(1000 * time.Millisecond) for { <-ticker.C log.Printf("%+v", p.Stat()) // 2021/04/26 14:32:53 &{Active:5 Idle:95 Total:100} } }()
License
Apache License Version 2.0, http://www.apache.org/licenses/
以上所述就是小编给大家介绍的《Mix XWP V1.1 - Go 通用动态协程池 WorkerPool》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!
猜你喜欢:- Nginx 通用网站镜像教程(适用于动态网站与静态网站)
- ClojureScript 1.10.312 发布,交互式动态通用编程语言
- SOFAMesh中的多协议通用解决方案X-protocol介绍系列(1)——DNS通用寻址方案
- CCM通用计算工具
- 通用xxe检测方法
- C#抽象通用方法
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
How to Solve It
Zbigniew Michalewicz、David B. Fogel / Springer / 2004-03-01 / USD 59.95
This book is the only source that provides comprehensive, current, and detailed information on problem solving using modern heuristics. It covers classic methods of optimization, including dynamic pro......一起来看看 《How to Solve It》 这本书的介绍吧!
