最大端口号是多少?

Yeh*_*sef 85 linux tcpip port

我想将一些 linux 服务设置为非标准端口 - 最高有效端口号是多少?

Mat*_*ons 87

(2^16)-1 或 0-65,535(-1 是因为端口 0 已保留且不可用)。(编辑是因为 o_O Tync 提醒我我们不能使用端口 0,而 Steve Folly 提醒我你要求的是最高端口,而不是端口数)

但你可能会以错误的方式解决这个问题。有人支持和反对非标准端口。我说它们与最随意的扫描器无关,并且可以通过使用最新的软件和适当的防火墙技术以及强密码来阻止最随意的扫描器。换句话说,安全最佳实践。

  • -1 表示错误答案。尝试 65,535。但是关于支持/反对非标准端口的论点的好点。 (3认同)
  • 有些安全/合规人员会强制做出此类决定。我们在预定的高端口上运行 SMTP 服务,以保护我们免受安全官员办公室的骚扰。 (2认同)
  • @Matt:删除-1 :-) (2认同)

kol*_*pto 49

1-65535 可用,1-1023 范围内的端口是特权端口:应用程序需要以 root 身份运行才能侦听这些端口。


小智 13

尽管 1-65535 是合法的 TCP 端口,但 1-1023 确实用于众所周知的端口服务。如果在建立临时端口后启动您自己的服务,您可能会遇到随机问题。对于那些可能不知道的人来说,临时端口是那些在本地连接到远程端点(或类似的东西)的端口。因此,如果您编写一个侦听端口 20001 的 TCP 服务。您今天可能会很好……明天也可能会很好。但是有一天你的服务可能会启动并尝试绑定到 20001 并且它会失败,因为它被当作一个临时端口。有一个解决方案。您必须让您的管理员或您自己更改服务器上的系统临时端口范围策略。在 linux 系统上,它分两步完成:

  • 动态地
  • 永久

这两个步骤都必须执行,除非您计划重新启动(在这种情况下不需要动态步骤)。要将范围设置为 40000 到 65535,请执行以下操作:

动态的

echo 40000 65535 > /proc/sys/net/ipv4/ip_local_port_range

或者

sysctl -w net.ipv4.ip_local_port_range="40000 65535"

永恒的

将以下内容添加到 /etc/sysctl.conf:

net.ipv4.ip_local_port_range = 40000 65535

要读取当前设置或确认更改:

/sbin/sysctl net.ipv4.ip_local_port_range

输出将是这样的:

net.ipv4.ip_local_port_range = 9000 65500

确保您了解服务器的用途。过度减少范围会导致其他问题。

快乐编码!(或无论你做什么)