根据TCP/IP协议限制,单个IP在对外发起连接时,理论上只能发起65535个连接,通常低于1024端口号都被系统保留,要创建多于65535个连接需要绑定多个ip。
所以不能任由Erlang虚拟机自己选择IP,需要在程序中指定IP绑定到socket。
而在实际过程中却无法突破65535这个数量,无论多少个虚拟机,多少个本地ip,连接的总数都只能到6万多。排查内核参数,并假定问题的可能性,最终发现是Erlang虚拟机本身的问题,Erlang虚拟机会顺序绑定端口,而不是和IP配对出现,这样在占用完6万多个端口后就宣告端口用尽。
解决的办法,不仅要绑定IP,还要指定端口。并跳过已经占用的ip:port。