内容简介: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#抽象通用方法
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
深入浅出Web设计(中文版)
(美)瓦特罗尔、(美)西罗托 / O'Reilly Taiwan公司 / 东南大学出版社 / 2010-11 / 99.00元
你将从《深入浅出Web设计(中文版)》学到什么?你曾经希望看看书就能学到真正的网站设计吗?曾经想过该如何同时达成让网站看起来美观,又能有效率地沟通信息,还要通过可访问性与可用性的策略吗?《深入浅出Web设计》正是精通上述主题的秘笈。我们将学到如何设计一个绝佳、用户友好的网站,上谈客户需求,下说手绘分镜表,乃至完成在线所需的HTML与css主文件……而且会有一个真正可以运作的网站!一起来看看 《深入浅出Web设计(中文版)》 这本书的介绍吧!