Golang 고루틴 워커 grpool 라이브러리 알아보기
오늘은 Golang으로 고루틴 워커를 만들어서 동시성 프로그래밍을 할 수 있는 grpool 라이브러리를 알아보려 합니다.
grpool 설치
우선 Golang의 환경을 구성하기 위해 https://golang.org/dl/ 에서 윈도우, 리눅스, 맥에서 설치 프로그램을 내려받을 수 있습니다.
맥에서 brew로 쉽게 설치할 수 있습니다.
brew install go
우분투에서도 apt로 쉽게 설치할 수 있습니다.
sudo apt-get install golang-go
맥에서 Golang의 버전을 올리려면 brew를 이용합니다.
brew upgrade go
우분투에서도 Golang의 버전을 올리려면 backports 저장소를 등록하고 apt를 이용합니다.
sudo add-apt-repository ppa:longsleep/golang-backports
sudo apt-get update
sudo apt-get install golang-go
go get으로 grpool 패키지를 설치합니다.
go get github.com/ivpusic/grpool
홈의 go 폴더에 grpool 소스코드와 패키지 파일이 생성됩니다.
예제
package main
해당 소스코드를 실행 파일로 인식하게 해주도록 main이라고 선언합니다.
import (
"fmt"
"github.com/ivpusic/grpool"
)
fmt와 grpool을 가져옵니다.
func main() {
pool := grpool.NewPool(100, 50)
고루틴 워커를 만듭니다.
pool.WaitCount(100)
WaitAll 메소드를 호출하기 전에 얼마나 많은 수의 워커를 기다려야 되는 지 정합니다.
for i := 0; i < 100; i++ {
value := i
pool.JobQueue <- func() {
defer pool.JobDone()
fmt.Println(value)
}
}
각자의 반복문에서 작업이 완료되어 JobDone 메소드를 부르면 워커가 끝났다고 통지합니다.
pool.WaitAll()
모든 작업이 끝날 때까지 기다립니다.
defer pool.Release()
}
풀의 자원을 릴리즈합니다.
Written on September 7, 2019