- GOMAXPROCS的作用是控制你的程序最大能跑满几个逻辑CPU,也就是通常我们说的几核几核
- 默认情况下GOMAXPROCS的值就是NumCPU()的值
- 程序中设置了GOMAXPROCS的值后,此后的所有程序都会被限制在这个值内,所以,要想单独控制某段程序的负载,请设置完后,再设置回来。如下测试案例,SleepWait控制最多使用一半的cpu,我的虚拟机是6核,所以cpu轻松跑到300%,10秒过后,如果我不把Test_GOMAXPROCS注释的那段放开,主程序也会最大负载300%
- 当程序已经有协程阻塞时,
runtime.GOMAXPROCS(runtime.NumCPU())
会被阻塞,直到所有协程都无阻塞。
func Test_GOMAXPROCS(t *testing.T) {
SleepWait(10 * time.Second)
fmt.Println("???")
// result := runtime.GOMAXPROCS(runtime.NumCPU())
// fmt.Println("result", result)
for i := 0; i < 8; i++ {
go func() {
for {
}
}()
}
select {}
}
func SleepWait(duration time.Duration) {
fmt.Println("?")
result := runtime.GOMAXPROCS(runtime.NumCPU() / 2)
fmt.Println("result", result)
done := make(chan bool)
for i := 0; i < 8; i++ {
go func() {
defer fmt.Println("!!")
for {
select {
case <-done:
return
default:
}
}
}()
}
fmt.Println("duration:", duration)
<-time.After(duration)
close(done)
fmt.Println("??")
}
网友评论