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 / 问题 / 68753
In Process
Derek Gathright
Derek Gathright
Asked: 2009-09-26 08:08:18 +0800 CST2009-09-26 08:08:18 +0800 CST 2009-09-26 08:08:18 +0800 CST

负载均衡器后面的每台服务器是否都需要自己的 SSL 证书?

  • 772

如果您在负载均衡器(例如 haproxy)后面有 5 个 Web 服务器,并且它们为同一个域提供内容,您是否需要所有服务器的 SSL 证书,或者您可以在每台服务器上使用相同的证书?

我知道您可以将所有 SSL 请求放在特定服务器上,但这需要分布式会话信息,并且希望它不会出现这种情况。

ssl
  • 5 5 个回答
  • 135005 Views

5 个回答

  • Voted
  1. user2874
    2009-09-26T08:30:23+08:002009-09-26T08:30:23+08:00

    如果您在负载均衡器 (...) 后面有 5 个 Web 服务器,您是否需要所有服务器的 SSL 证书,

    这取决于。

    如果您在 TCP 或 IP 层(OSI 第 4/3 层,也称为 L4、L3)上进行负载平衡,那么是的,所有 HTTP 服务器都需要安装 SSL 证书。

    如果您在 HTTPS 层 (L7) 上进行负载平衡,那么您通常会单独在负载平衡器上安装证书,并在负载平衡器和 Web 服务器之间的本地网络上使用普通未加密的 HTTP(以获得最佳性能网络服务器)。

    如果您有大型安装,那么您可能正在执行 Internet -> L3 负载平衡 -> L7 SSL 集中器层 -> 负载平衡器 -> L7 HTTP 应用程序服务器层...

    HAProxy 的作者 Willy Tarreau对负载平衡 HTTP/HTTPS的规范方法有一个非常好的概述。

    如果您在每台服务器上安装证书,请确保获得支持此功能的证书。通常证书可以安装在多台服务器上,只要这些服务器都只为一个完全限定域名提供流量。但是验证您购买的是什么,证书颁发者可能会有一个令人困惑的产品组合......

    • 77
  2. Ryan Fisher
    2009-09-26T08:18:48+08:002009-09-26T08:18:48+08:00

    您应该能够在每台服务器上使用相同的证书。如果您的网站是 www.gathright.com,您应该可以购买该 FQDN 的证书。然后将其安装在平衡器后面的 5 台服务器上。

    或者,您可以为每个 Web 服务器获取一个单独的证书,但将“www.gathright.com”作为“主题备用名称”包括在内,这意味着 5 个证书中的每一个对于该通用 FQDN 的 SSL 以及 SSL 都有效到特定的服务器 FQDN。

    • 17
  3. yfeldblum
    2011-04-28T05:44:13+08:002011-04-28T05:44:13+08:00

    是的,您可以在所有服务器上使用相同的证书和关联的私钥,前提是它们位于负载均衡器或负载均衡反向代理之后,并且它们都在为同一个域提供内容。

    证书在由证书颁发机构签名时,断言证书颁发机构验证了证书上列出的名称。对于网站的证书,这意味着网站的域名。您的浏览器希望与它通信的服务器(如果它通过 HTTPS 通信)提供与浏览器认为正在与之通信的域名同名的证书。(例如,VeriSign 不太可能为 bankofamerica.com 签署 Hacker Joe 的证书。因此,即使 Hacker Joe 设法拦截了您与 bankofamerica.com 之间的流量,Hacker Joe 也不会为 bankofamerica.com 和您的浏览器签署证书将在整个地方竖起大红色警告标志。)

    重要的是证书上的名称与浏览器认为正在与之交谈的域名相匹配。您可以在 Web 集群中的多个 Web 服务器上使用具有正确名称的相同证书(带有关联的私钥),只要它们位于负载均衡器后面。

    您还可以使用 SSL 终止负载均衡器,在这种情况下,您将在负载均衡器上使用证书(带有关联的私钥),并且 Web 服务器不需要证书,因为它们与它们没有任何关系SSL。

    • 14
  4. jotango
    2009-12-09T13:02:42+08:002009-12-09T13:02:42+08:00

    我们的设置运行良好:

    https trafic
         |
       pound
         |
    http traffic
         |
      haproxy
         |
    http traffic 
         |
    web server 1 ... web server n
    

    这种方式磅解密流量,从这里开始一切都是直接的http。优点:Web 服务器上的配置较少,每个作业一个工具。您可以最大限度地利用磅机上的 CPU,并保持 Web 服务器“正常”。如果正常运行时间很重要,您应该至少获得两个(磅、haproxy、网络服务器)。

    • 7
  5. joeqwerty
    2009-09-26T08:17:18+08:002009-09-26T08:17:18+08:00

    AFAIR,您可以在每台服务器上使用相同的证书。您还可以实施 SSL 加速器并将所有 SSL 流量卸载到它。

    • 3

相关问题

  • 如何使用 Tomcat 5.5 更新 SSL 证书

  • 为 IIS6 自行生成 SSL 证书?

  • plesk 上的域和子域 ssl 访问

  • 如何设置 SSL 邮件服务器?

  • 如何通过 SVN 命令行接受 SSL 证书?

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