共计 614 个字符,预计需要花费 2 分钟才能阅读完成。
今天在一个服务器上部署一个 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 让其生效
本文永久更新链接地址 :http://www.linuxidc.com/Linux/2016-01/127905.htm