这是一个简单的 Go http (tcp) 连接测试脚本
func main() {
ts := httptest.NewServer(http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
fmt.Fprintln(w, "Hello, client")
}))
defer ts.Close()
var wg sync.WaitGroup
for i := 0; i < 2000; i++ {
wg.Add(1)
go func(i int) {
defer wg.Done()
resp, err := http.Get(ts.URL)
if err != nil {
panic(err)
}
greeting, err := ioutil.ReadAll(resp.Body)
resp.Body.Close()
if err != nil {
panic(err)
}
fmt.Printf("%s", i, greeting)
}(i)
}
wg.Wait()
}
如果我在 Ubuntu 中运行它,我会得到:
panic: Get http://127.0.0.1:33202: dial tcp 127.0.0.1:33202: too many open files
其他帖子说要确保Close连接,我在这里做这一切。和其他人说增加最大连接的限制ulimit或尝试sudo sysctl -w fs.inotify.max_user_watches=100000但仍然不起作用。
如何在单个服务器中运行数百万个 tcp 连接 goroutines?它仅在 2,000 个连接时崩溃。
婷婷同学_
摇曳的蔷薇
相关分类