> 백엔드 개발 > Golang > 동시 Go 루틴을 효과적으로 제한하는 방법은 무엇입니까?

동시 Go 루틴을 효과적으로 제한하는 방법은 무엇입니까?

Barbara Streisand
풀어 주다: 2024-11-02 05:25:02
원래의
875명이 탐색했습니다.

How to Effectively Limit Concurrent Go Routines?

동시 Go 루틴 제한

코드에서 동시 Go 루틴 수를 제한하려고 합니다. 그러나 현재 구현은 의도한 대로 작동하지 않습니다. 대체 접근 방식은 다음과 같습니다.

해결책:

각 URL에 대해 goroutine을 만드는 대신 공유 채널에서 URL을 처리하는 고정된 수의 작업자를 만듭니다. 수정된 코드는 다음과 같습니다.

<code class="go">parallel := flag.Int("parallel", 10, "max parallel requests allowed")
flag.Parse()

// Workers get URLs from this channel
urls := make(chan string) 

// Feed the workers with URLs
go func() {
    for _, u := range flag.Args() {
        urls <- u
    }
    // Workers will exit from range loop when channel is closed
    close(urls)
}()

var wg sync.WaitGroup
client := rest.Client{}

results := make(chan string)

// Start the specified number of workers.
for i := 0; i < *parallel; i++ {
    wg.Add(1)
    go func() {
        defer wg.Done()
        for url := range urls {
            worker(url, client, results)
        }
    }()
}

// When workers are done, close results so that main will exit.
go func() {
    wg.Wait()
    close(results)
}()

for res := range results {
    fmt.Println(res)
}</code>
로그인 후 복사

설명:

  • 버퍼링된 채널 URL이 생성되어 작업자에게 URL이 제공됩니다.
  • 별도의 고루틴은 제공된 URL을 URL 채널에 공급하는 역할을 담당합니다.
  • 원하는 수의 워커가 생성됩니다. 각 작업자는 URL 채널에서 URL을 가져와 순차적으로 처리합니다.
  • 모든 작업자가 처리를 마치면 고루틴은 결과 채널을 닫아 모든 결과가 검색되었음을 알립니다.

이것은 접근 방식을 사용하면 주어진 시간에 최대 병렬 고루틴이 활성화되어 동시성을 원하는 대로 제한할 수 있습니다.

위 내용은 동시 Go 루틴을 효과적으로 제한하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿