是的呢,我又回来了。
昨天讲了一个没有结局的故事,今天就被教育了。
这段代码开了10个并发去跑的时候, duang!!
ERROR: TOO MANY OPEN FILES
第一感觉: 简单,改ulimit就好了么。
但是真的好吗,只是掩耳盗铃么。为什么会报这个错误哦,才10么!
在@LYY的建议下,换用了一个叫goreq的包,来替代原生的http请求方式。代码如下:
上线之后确实就好了,不再报错。
很奇怪,看了下源码:
goreq是定义了一个全局的client对象。
是的,我之前的代码在每个goroutine里面都创建了一个client,导致句柄不能及时释放。
以上。
有疑问加站长微信联系(非本文作者)