首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >上游加密Nginx `proxy_ssl_trusted_certificate`

上游加密Nginx `proxy_ssl_trusted_certificate`
EN

Stack Overflow用户
提问于 2021-02-09 00:23:28
回答 1查看 3.1K关注 0票数 2

我试图在nginx中使用proxy_pass,其中对上游服务器的连接进行了加密。上游服务器的证书已由letsencrypt创建。

代码语言:javascript
复制
# upstream server: nginx.conf

stream {
  server {
    listen 636 ssl;

    ssl_certificate /etc/letsencrypt/live/upstream.example.com/fullchain.pem; # managed by Certbot
    ssl_certificate_key /etc/letsencrypt/live/upstream.example.com/privkey.pem; # managed by Certbot

    # ...
  }
}

当不验证下游服务器中的代理证书时,一切正常。

代码语言:javascript
复制
# downstream server: nginx.conf

stream {
  server {
    listen 636 ssl;

    ssl_certificate /etc/letsencrypt/live/downstream.example.com/fullchain.pem; # managed by Certbot
    ssl_certificate_key /etc/letsencrypt/live/downstream.example.com/privkey.pem; # managed by Certbot

    proxy_ssl on;
    proxy_ssl_verify off;

    proxy_pass upstream.example.com:636;

    # ...

  }
}

但是,如果我试图在下游服务器上验证上游证书,则在nginx错误日志中获得上游SSL证书验证错误:(2:无法获得颁发者证书)而SSL与上游握手。

代码语言:javascript
复制
# downstream server: nginx.conf

stream {
  server {
    listen 636 ssl;

    ssl_certificate /etc/letsencrypt/live/downstream.example.com/fullchain.pem; # managed by Certbot
    ssl_certificate_key /etc/letsencrypt/live/downstream.example.com/privkey.pem; # managed by Certbot

    proxy_ssl on;
    proxy_ssl_verify on;
    proxy_ssl_trusted_certificate /etc/nginx/ssl/upstream.example.com/chain.pem;
    proxy_ssl_verify_depth 2;

    proxy_pass upstream.example.com:636;

    # ...

  }
}

如果我试图连接的上游服务器有一个letsencrypt证书,那么我需要proxy_ssl_trusted_certificateproxy_ssl_verify_depth的哪些设置?

我将proxy_ssl_verify_depth从0更改为5,并使用了上游服务器的fullchain.pemchain.pemcert.pem for proxy_ssl_trusted_certificate,但都没有成功。

更多信息

使用openssl验证CA证书有效:

代码语言:javascript
复制
# openssl verify -verify_depth 2 chain.pem
chain.pem: OK

根据CA证书验证来自上游服务器fullchain.pem的证书工作:

代码语言:javascript
复制
# openssl verify -CAfile chain.pem fullchain.pem
fullchain.pem: OK

进一步参考资料

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2021-02-09 21:08:22

proxy_ssl_trusted_certificate所需的CA证书不是由letsencrypt或上游服务器提供的。它已经安装在下游服务器上。

在Ubuntu上,CA证书的位置是/etc/ssl/certs/ca-certificates.crt

代码语言:javascript
复制
# downstream server: nginx.conf

stream {
  server {
    listen 636 ssl;

    ssl_certificate /etc/letsencrypt/live/downstream.example.com/fullchain.pem; # managed by Certbot
    ssl_certificate_key /etc/letsencrypt/live/downstream.example.com/privkey.pem; # managed by Certbot

    proxy_ssl on;
    proxy_ssl_verify on;
    proxy_ssl_trusted_certificate /etc/ssl/certs/ca-certificates.crt;

    proxy_pass upstream.example.com:636;

    # ...

  }
}

文档

https://nginx.org/en/docs/http/ngx_http_proxy_module.html

打开

proxy_ssl_verify;启用或禁用对代理HTTPS服务器证书的验证。

proxy_ssl_verify_depth编号;在代理的HTTPS服务器证书链中设置验证深度。

proxy_ssl_trusted_certificate文件;指定具有可信CA证书的文件,格式为PEM格式,用于验证代理HTTPS服务器的证书。

另请参阅

票数 4
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/66111292

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档