幕布斯6054654
Job/Worker 模式是适用于此任务的常见 go 并发模式。多个 goroutine 可以从单个通道读取,在 CPU 内核之间分配大量工作,因此是工作程序的名称。在 Go 中,这种模式很容易实现——只需启动多个以通道为参数的 goroutine,然后将值发送到该通道——分发和多路复用将由 Go 运行时完成。package mainimport ( "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/
0
0