Mix XWP V1.1 - Go 通用动态协程池 WorkerPool

onanying · · 3126 次点击 · 开始浏览    置顶
这是一个创建于 的主题,其中的信息可能已经有所发展或是发生改变。

> OpenMix 出品:[https://openmix.org](https://openmix.org/mix-go) ## Mix XWP 通用的工作池 A common worker pool ## Github [https://github.com/mix-go/xwp](https://github.com/mix-go/xwp) ## Installation ``` go get github.com/mix-go/xwp ``` ## Usage 先创建一个结构体用来处理任务,使用类型断言转换任务数据类型,例如:`i := data.(int)` ~~~go type Foo struct { } func (t *Foo) Do(data interface{}) { // do something } ~~~ 调度任务 - 也可以使用 `RunF` 采用闭包来处理任务 - 如果不想阻塞执行,可以使用 `p.Start()` 启动 ~~~go 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` 获取异常信息记录到日志或者执行其他处理 ~~~go func (t *Foo) Do(data interface{}) { defer func() { if err := recover(); err != nil { // handle error } }() // do something } ~~~ 查看 `Workers` 的执行状态:通常可以使用一个定时器,定时打印或者告警处理 ```go 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/

有疑问加站长微信联系(非本文作者)

入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889

3126 次点击  
加入收藏 微博
暂无回复
添加一条新回复 (您需要 登录 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
  • 图片支持拖拽、截图粘贴等方式上传