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 / 问题 / 822394
Accepted
JonDoe297
JonDoe297
Asked: 2016-12-23 20:50:18 +0800 CST2016-12-23 20:50:18 +0800 CST 2016-12-23 20:50:18 +0800 CST

HAProxy:如果我绑定到端口 32768-65535,计算机将无法访问其他服务器

  • 772

我需要像这样配置一个 HAProxy 前端:

frontend web-server
    option forwardfor       except 127.0.0.0/8

    bind :8080
    bind :32768-65535

    default_backend service

但是,该配置不允许我连接到内部或外部的其他服务器。

$ wget www.google.com
--2016-12-22 23:21:13--  http://www.google.com/
Resolving www.google.com (www.google.com)... 172.217.6.196, 2607:f8b0:4006:804::2004
Connecting to www.google.com (www.google.com)|172.217.6.196|:80... failed: Cannot assign requested address.
Connecting to www.google.com (www.google.com)|2607:f8b0:4006:804::2004|:80... failed: Network is unreachable.

如果我注释该行bind :32768_65535并重新启动 HAProxy,我可以再次连接到其他服务器。

我想我正在将 HAProxy 绑定到启动连接所需的端口,这就是该配置导致此问题的原因。

如何配置 HAProxy 以侦听这些端口,而不会出现连接问题?

编辑:

  • HAProxy 1.6
  • Ubuntu 16.04(全新安装)
haproxy
  • 1 1 个回答
  • 1172 Views

1 个回答

  • Voted
  1. Best Answer
    Michael Hampton
    2016-12-23T20:58:11+08:002016-12-23T20:58:11+08:00

    因此,haproxy 绑定了从 32768 到 65535(含)的每个本地端口。这是一个问题,因为默认情况下,传出连接会绑定此范围内的本地端口:

    # sysctl net.ipv4.ip_local_port_range
    net.ipv4.ip_local_port_range = 32768    60999
    

    要解决此问题,您需要选择一个不会在您的系统上使用的本地端口范围,并重新配置此 sysctl 以使用它。例如:

    sudo sysctl -w net.ipv4.ip_local_port_range="24576 32767"
    

    (并使其持久化/etc/sysctl.conf。)

    • 4

相关问题

  • 具有动态路由的代理服务器

  • nginx 访问日志忽略某些请求

  • HAProxy 和“分片”

  • 带有 HAProxy 的远程 IP

  • SSL 网站的高可用性

Sidebar

Stats

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

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

    • 5 个回答
  • Marko Smith

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

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

    • 9 个回答
  • Marko Smith

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

    • 3 个回答
  • Marko Smith

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

    • 15 个回答
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +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