客户端发起超过6w个连接

    在内存、cpu、带宽足够的情况下,当我们编写客户端代码发起socket连接,在连接开到超过6w多之后就会开始出现无法分配地址的错误。因为,socket客户端在发起连接到server的同时也会开启一个端口进行通讯,client在server那边的标记是ip:port。port的上限是65535,没办法突破这个大小,那我们只需要增加ip的选择就可以了,那样可以开的客户端连接的数量=ip数量*65535-已经被占用的端口,让我们的一台pc可以发起100k连接。

     各种系统都存在设置虚拟ip(一个网卡绑定多个ip的方式)的方案,非常的简单。这里就不描述了,这里想分享的是,一些常用的代码发起socket连接的绑定固定ip的方式。这里的绑定不仅仅是只有server端,其实同样的client端也可以绑定ip。

//golang
netAddr := &net.TCPAddr{IP:net.ParseIP("指定ip")}
d := net.Dialer{Timeout: timeout, LocalAddr: netAddr}
conn, err := d.Dial("tcp", "xxx:10086")
//java
Socket s = new Socket();
s.bind(new InetSocketAddress("localhostIP", 5000));
s.connect(new InetSocketAddress("google.com", 80));

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章