AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / server / 问题 / 103626
Accepted
Yehosef
Yehosef
Asked: 2010-01-18 15:53:19 +0800 CST2010-01-18 15:53:19 +0800 CST 2010-01-18 15:53:19 +0800 CST

最大端口号是多少?

  • 772

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

linux port tcpip
  • 3 3 个回答
  • 149765 Views

3 个回答

  • Voted
  1. Best Answer
    Matt Simmons
    2010-01-18T15:58:08+08:002010-01-18T15:58:08+08:00

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

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

    • 94
  2. kolypto
    2010-01-18T15:56:42+08:002010-01-18T15:56:42+08:00

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

    • 50
  3. Stephen Mathews
    2017-09-14T07:55:02+08:002017-09-14T07:55:02+08:00

    虽然 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

    确保您了解服务器的用途。将范围缩小太多可能会导致其他问题。

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

    • 14

相关问题

  • 你最喜欢的 Linux 发行版是什么?[关闭]

  • 如何在 Windows Server PPTP VPN 中自动为客户端分配路由?

  • 更改 PHP 的默认配置设置?

  • 保护新的 Ubuntu 服务器 [关闭]

  • (软)Ubuntu 7.10 上的 RAID 6,我应该迁移到 8.10 吗?

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    新安装后 postgres 的默认超级用户用户名/密码是什么?

    • 5 个回答
  • Marko Smith

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

    从 IP 地址解析主机名

    • 8 个回答
  • Marko Smith

    如何按大小对 du -h 输出进行排序

    • 30 个回答
  • Marko Smith

    命令行列出 Windows Active Directory 组中的用户?

    • 9 个回答
  • Marko Smith

    什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同?

    • 3 个回答
  • Marko Smith

    如何确定bash变量是否为空?

    • 15 个回答
  • Martin Hope
    MikeN 在 Nginx 中,如何在维护子域的同时将所有 http 请求重写为 https? 2009-09-22 06:04:43 +0800 CST
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    0x89 bash中的双方括号和单方括号有什么区别? 2009-08-10 13:11:51 +0800 CST
  • Martin Hope
    Kyle Brandt IPv4 子网如何工作? 2009-08-05 06:05:31 +0800 CST
  • Martin Hope
    Noah Goodrich 什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同? 2009-05-19 18:24:42 +0800 CST
  • Martin Hope
    Brent 如何确定bash变量是否为空? 2009-05-13 09:54:48 +0800 CST
  • Martin Hope
    cletus 您如何找到在 Windows 中打开文件的进程? 2009-05-01 16:47:16 +0800 CST

热门标签

linux nginx windows networking ubuntu domain-name-system amazon-web-services active-directory apache-2.4 ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve