端口没被占用,怎么会bind失败呢?


今天在一个服务器上部署一个webserver的时候,

提示我bind端口失败,

我习惯性的用netstat看了下,没有被占用啊!

 

把问题分享出来后,给力的同事们搜索到了ip_local_port_range这个东西

这个东西对应的是/proc/sys/net/ipv4/ip_local_port_range文件

我打开后发现它的内容是:

1024 65000

 

然后我查了一下,这两个数字就是规定了一个端口范围

而这个文件规定了所谓的“临时端口”的可用端口范围

比如一个程序通过socket请求了本机外的一个服务,

以为内socket的要求是通信的双发都是一个ip加一个端口的,

我们在请求时,只会指定要请求的ip和端口,并没有指定本机的,

那这时按照Linux的策略,是自动分配一个临时端口的

而这个临时端口可取的范围就是这个ip_local_port_range

 

ip_local_port_range还有一个隐藏的属性,就是这个临时端口范围内的端口,不能被bind

这也就是我一开始遇到的问题的原因了

 

当我想编辑这个文件来修改范围时,发现修改后时无法保存的

然后搜索了一下,说要永久修改,可以:

vim /etc/sysctl.conf

修改其中的net.ipv4.ip_local_port_range

保存后执行sysctl -p让其生效

本文永久更新链接地址

相关内容