我有一个非常消耗 CPU 的玩具网络应用程序
func PerfServiceHandler(w http.ResponseWriter, req *http.Request)
{
start := time.Now()
w.Header().Set("Content-Type", "application/json")
x := 0
for i := 0; i < 200000000; i++ {
x = x + 1
x = x - 1
}
elapsed := time.Since(start)
w.Write([]byte(fmt.Sprintf("Time Elapsed %s", elapsed)))
}
func main()
{
http.HandleFunc("/perf", PerfServiceHandler)
http.ListenAndServe(":3000", nil)
}
执行上述函数大约需要 120 毫秒。但是当我用 500 个并发用户(siege -t30s -i -v -c500 http://localhost:3000/perf)对这个应用程序进行负载测试时,我得到了结果
每个请求的平均响应时间 2.51 秒
交易速率每秒 160.57 笔交易
有人可以在下面回答我的问题吗:-
当我运行 100、200、500 个并发用户时,我看到没有。当应用程序刚启动时,上述应用程序使用的操作系统线程数从 7 卡到了 35。增加并发连接数不会改变这个数字。即使当 500 个并发请求到达服务器时,操作系统线程的数量仍然停留在 35 个操作系统线程(应用程序以 runtime.GOMAXPROCS(runtime.NumCPU()) 启动)。当测试停止时,数字仍然是 35。
有人可以向我解释这种行为吗?
可以没有。以某种方式增加操作系统线程的数量(来自操作系统或来自 GOlang)?
如果没有,这会提高性能吗?操作系统线程增加了?
有人可以建议一些其他优化此应用程序的方法吗?