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 / 问题 / 25071
In Process
Darren
Darren
Asked: 2009-06-13 14:20:46 +0800 CST2009-06-13 14:20:46 +0800 CST 2009-06-13 14:20:46 +0800 CST

Web 服务器前的反向代理会提高安全性吗?

  • 772

第三方安全专家建议我们在 Web 服务器(所有托管在 DMZ 中)前面运行反向代理,作为最佳实践安全措施。

我知道这是一个典型的推荐架构,因为它在 Web 应用程序前面提供了另一个级别的安全性来防止黑客。

然而,由于反向代理在用户和内部网络服务器之间来回传输 HTTP,它不会提供任何措施来防止网络服务器本身被黑客入侵。换句话说,如果您的 Web 应用程序存在安全漏洞,代理将不会提供任何有意义的安全性。

鉴于攻击 Web 应用程序的风险远高于攻击代理的风险,在中间添加一个额外的框是否真的有很多好处?我们不会使用反向代理的任何缓存功能——只是一个来回传送数据包的愚蠢工具。

还有什么我在这里想念的吗?反向代理 HTTP 数据包检测是否变得如此出色,可以检测到有意义的攻击而不会出现重大性能瓶颈,或者这只是安全剧院的另一个例子?

反向代理是 MS ISA fwiw。

security isa-server proxy reverse-proxy
  • 7 7 个回答
  • 38842 Views

7 个回答

  • Voted
  1. David Pashley
    2009-06-13T15:29:09+08:002009-06-13T15:29:09+08:00

    Apache 有 mod_security,它将检测常见的安全攻击。还有 mod_cband,可以限制使用的带宽。如果 ISA 有类似的东西,我不会感到惊讶。如果在 HTTP 流量通过代理时没有实际检查它,从安全角度来看,这一切都毫无意义。

    反向代理将为您提供负载平衡、故障转移、缓存、SSL 和文件卸载,让您的 Web 服务器去做它们擅长的事情:提供 HTML。

    • 9
  2. Aaron Weiker
    2009-06-13T14:30:53+08:002009-06-13T14:30:53+08:00

    ISA Server 能够查找并阻止各种 HTTP 漏洞,并阻止它们进入 Web 服务器。虽然大多数现代 HTTP 服务器不再可被此利用,但它确实具有不将此流量发送到 Web 服务器的额外好处。

    此外,ISA 可以更轻松地完成诸如添加 SSL 加速和用户对各种 URL 的预授权等操作。它甚至可以充当您的负载均衡器,因此您可以轻松添加更多 Web 服务器,而无需使用单独的硬件负载均衡器。

    一定要考虑这个人在 ISA 上给出的专家意见,并将其与管理和运行 ISA 所需的额外开销与收益相比较来衡量。

    • 8
  3. Zoredache
    2009-06-13T15:56:45+08:002009-06-13T15:56:45+08:00

    Web 服务器前的反向代理会提高安全性吗?

    反向代理为您提供了一些可以使您的服务器更安全的东西。

    • 一个独立于 Web 服务器的地方来监控和记录正在发生的事情
    • 如果您知道系统的某些区域易受攻击,则可以将过滤器或防火墙与您的 Web 服务器分开。根据代理,您可能能够在应用程序级别进行过滤。
    • 如果您由于某种原因在 Web 服务器上的表达能力不够,则可以在另一个地方实现 ACL 和规则。
    • 一个单独的网络堆栈,不会像您的 Web 服务器一样容易受到攻击。如果您的代理来自不同的供应商,则尤其如此。
      • 在 Apache 服务器前使用 Apache 设置作为代理可能不如在 Apache 前使用 Squid 之类的东西有用。

    没有过滤的反向代理不会自动保护您免受一切侵害,但如果您需要保护的系统是高价值的,那么添加反向代理可能值得成本支持和性能成本。

    • 8
  4. freiheit
    2009-06-13T14:26:42+08:002009-06-13T14:26:42+08:00

    它可以保护您的应用程序服务器免受基于错误 HTTP 请求的攻击......特别是如果可以在反向代理(而不是应用程序服务器)上准确配置良好请求的外观并且不允许错误请求通过。如果你必须告诉它糟糕的请求是什么样的,它几乎肯定是没用的。换句话说,它可以防止缓冲区溢出攻击,但不能防止 SQL 注入。

    大多数情况下,这听起来像安全剧院。您聘请了一名安全顾问,他们必须告诉您一些措施来提高您的安全性。攻击者不太可能闯入反向代理,如果他们只是绕过它,他们总是会责怪你;所以这是一个安全的建议。

    • 6
  5. Xavier Nicollet
    2015-11-17T07:25:42+08:002015-11-17T07:25:42+08:00

    基本上,反向代理会将您的基础设施隐藏起来。所以这主要是一个默默无闻的安全案例,除非你的网络服务器真的难以管理和不安全。

    它还可以保护您的网络服务器免受某种 DOS(分布式拒绝服务)的影响,特别是如果您的网站“很重”,则充当缓存层。

    它也有一些陷阱:它将向您的应用程序隐藏客户的真实 IP。它会让你消耗更多的服务器功率,并增加一层可以破坏的东西。请记住,您的反向代理将不得不处理更多的连接(通常是两倍:与客户的连接和与您的 Web 服务器的连接)。

    归根结底,反向代理无论如何都不会让您拥有一个安全的网站。

    • 3
  6. warchitect
    2015-11-17T06:43:29+08:002015-11-17T06:43:29+08:00

    我认为其他人没有谈论过的一个好处是您不必通过外部防火墙打开任何外部 IP/端口。一个好的反向代理系统将启动从您的网络内部到 DMZ 中的服务器的通信,保护网络免受直接攻击。然而,正如其他人所说,这不会保护您免受编写不佳的应用程序的影响。

    • 1
  7. ChrisNZ
    2009-06-14T03:37:32+08:002009-06-14T03:37:32+08:00

    我认为 Zoredache 对反向代理可以提供的好处给出了一个很好的答案。我使用了 Pound,它是一个反向代理、负载均衡器和 HTTPS 前端。

    http://www.apsis.ch/pound/

    • 0

相关问题

  • 为什么使用authorized_keys通过ssh自动登录不起作用?

  • 如何启用与 SQL Server 实例的加密连接?

  • 从多个位置保护远程服务器/工具访问的最佳方法是什么?

  • 在 SOHO 环境中实施的最佳 VPN 技术是什么?[关闭]

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

Sidebar

Stats

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

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

    从 IP 地址解析主机名

    • 8 个回答
  • Marko Smith

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

    • 30 个回答
  • Marko Smith

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

    • 9 个回答
  • Marko Smith

    Windows 中执行反向 DNS 查找的命令行实用程序是什么?

    • 14 个回答
  • Marko Smith

    如何检查 Windows 机器上的端口是否被阻塞?

    • 4 个回答
  • Marko Smith

    我应该打开哪个端口以允许远程桌面?

    • 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
    kch 如何更改我的私钥密码? 2009-08-06 21:37:57 +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