"If a worker wants to do his job well, he must first sharpen his tools." - Confucius, "The Analects of Confucius. Lu Linggong"
Front page > Programming > How to keep a fixed number of concurrent Goroutines running in Go?

How to keep a fixed number of concurrent Goroutines running in Go?

Posted on 2025-04-19
Browse:504

How to Maintain a Constant Number of Simultaneously Running Goroutines in Go?

Threading Goroutines in Go: Running a Constant Number Simultaneously

The realm of Go concurrency offers a plethora of materials on awaiting the completion of a specified number of goroutines. However, a distinct challenge presents itself: ensuring a continuous execution of a predefined number of goroutines, with one commencing as another concludes.

Consider a scenario with a substantial quantity of tasks, such as processing data retrieved from a MySQL database. A naive approach might initiate a vast number of parallel goroutines, simultaneously executing hundreds of thousands of tasks. In contrast, the desired behavior limits the concurrently running goroutines to a fixed count (say, 20).

This controlled concurrency pattern is known as "bounded parallelism." Implementing this pattern in Go entails employing a channel of empty structs as a semaphore, dictating the maximum number of concurrent worker goroutines. Here's an illustration:

package main

import "fmt"

func main() {
    maxGoroutines := 10
    guard := make(chan struct{}, maxGoroutines)

    for i := 0; i 

This implementation ensures that no more than the specified number of goroutines execute concurrently. As a result, when a worker goroutine finishes, a new goroutine is immediately launched, maintaining the desired concurrency level.

The "Go Concurrency Patterns" article further explores this concept in its "Bounded parallelism" section, providing deeper insights into this crucial concurrency technique.

Latest tutorial More>

Disclaimer: All resources provided are partly from the Internet. If there is any infringement of your copyright or other rights and interests, please explain the detailed reasons and provide proof of copyright or rights and interests and then send it to the email: [email protected] We will handle it for you as soon as possible.

Copyright© 2022 湘ICP备2022001581号-3