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

时间:2021-08-26 18:13:11

今天在一个服务器上部署一个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让其生效