1 回答
TA贡献1876条经验 获得超7个赞
Job/Worker 模式是适用于此任务的常见 go 并发模式。
多个 goroutine 可以从单个通道读取,在 CPU 内核之间分配大量工作,因此是工作程序的名称。在 Go 中,这种模式很容易实现——只需启动多个以通道为参数的 goroutine,然后将值发送到该通道——分发和多路复用将由 Go 运行时完成。
package main
import (
"fmt"
"sync"
"time"
)
func worker(tasksCh <-chan int, wg *sync.WaitGroup) {
defer wg.Done()
for {
task, ok := <-tasksCh
if !ok {
return
}
d := time.Duration(task) * time.Millisecond
time.Sleep(d)
fmt.Println("processing task", task)
}
}
func pool(wg *sync.WaitGroup, workers, tasks int) {
tasksCh := make(chan int)
for i := 0; i < workers; i++ {
go worker(tasksCh, wg)
}
for i := 0; i < tasks; i++ {
tasksCh <- i
}
close(tasksCh)
}
func main() {
var wg sync.WaitGroup
wg.Add(36)
go pool(&wg, 36, 50)
wg.Wait()
}
所有的 goroutine 并行运行,等待通道给它们工作。goroutine 几乎是一个接一个地立即接收它们的工作。
这是一篇关于如何在 go 中每分钟处理 100 万个请求的精彩文章:http: //marcio.io/2015/07/handling-1-million-requests-per-minute-with-golang/
- 1 回答
- 0 关注
- 185 浏览
添加回答
举报
