原因是短时间内new Socket操作过多, 而socket.close()操作并不能立即释放绑定的端口, 而是把端口设置为TIME_WAIT状态过段时间(默认240s)才释放, (用netstat -na可以看到)最后系统资源耗尽, (windows上是耗尽了pool of ephemeral ports 这段区间在1024-5000之间),
一种最容易实现但是很耗时的解决办法就是在new Socket操作之前增加TIME_WAIT时间的延迟,确保端口被释放。
原因是短时间内new Socket操作过多, 而socket.close()操作并不能立即释放绑定的端口, 而是把端口设置为TIME_WAIT状态过段时间(默认240s)才释放, (用netstat -na可以看到)最后系统资源耗尽, (windows上是耗尽了pool of ephemeral ports 这段区间在1024-5000之间),
一种最容易实现但是很耗时的解决办法就是在new Socket操作之前增加TIME_WAIT时间的延迟,确保端口被释放。