在实际使用中,有时候启动会遇到bind: address already in use
的问题,
但是通过lsof -i :10080
命令往往又看不到哪个进程占用了端口,
这时候就需要使用另一个命令了
netstat -an | grep "10080"
tcp 0 0 10.200.20.39:10080 10.200.20.40:2380 TIME_WAIT
tcp 0 0 10.200.20.39:10080 10.200.20.41:2380 TIME_WAIT
发现还存在处于TIME_WAIT的连接。
原因是什么呢
当你调用close()系统调用的时候,你只是close了socket的interface,并不是socket本身。具体什么时候关闭socket取决于内核,这个时间一般在20s到4分钟,官方的说法是4分钟,关于TIME_WAIT的具体说明详见 2.7 Please explain the TIME_WAIT state..