JSTUN 出现 java.net.BindException: Address already in use: Cannot bind

来源:互联网 发布:互联网程序员 编辑:程序博客网 时间:2024/06/05 07:20

使用JSTUN,进行NAT穿越的时候,总是出现java.net.BindException: Address already in use: Cannot bind

换其他机器测试,没有问题。只有自己机器运行出现这个问题。

打开JSTUN源码,查看DiscoveryTest 的 Test2() 方法  170行;

int localPort = sendSocket.getLocalPort();

InetAddress localAddress = sendSocket.getLocalAddress();
sendSocket.close();

DatagramSocket receiveSocket = new DatagramSocket(localPort, localAddress);
receiveSocket.connect(ca.getAddress().getInetAddress(), ca.getPort());
receiveSocket.setSoTimeout(timeout);

是在Socket获取本地端口,然后再构造 DatagramSocket(localPort, localAddress);

经过调试,原因是因为线程, 没有执行到sendSocket.close(); 方法,就去执行new DataGramSocket(localPort , localAddress);

端口未关闭,就去构造新的Socket,就出现的以上异常信息。


在close(); 之后,执行:

try {
Thread.sleep(5);
//CPU 睡眠10毫秒,否则会出现端口还未关闭,就开始执行下面的new 语句,出现端口被占用异常(可能出四核八线程机器才有的问题)
} catch (InterruptedException e) {
e.printStackTrace();
}