我已成功将 Apache (2.4.7) 配置为需要客户端证书,并且 - 作为反向代理 - 将证书中的信息转发到 Tomcat 8 服务器。
然而,当试图用 Spring Boot 完成同样的事情时,它失败了
The proxy server received an invalid response from an upstream server
The proxy server could not handle the request GET /myapp
并返回 HTTP 502 错误代码。
相关的工作 Tomcat 配置是:
<Connector SSLEnabled="true" clientAuth="want" keyAlias="myalias"
keystoreFile="mystore.jks" keystorePass="mypassword" maxThreads="150"
port="8443" protocol="HTTP/1.1" scheme="https" secure="true"
sslProtocol="TLS" truststoreFile="mystore.jks" truststorePass="mypassword"/>
Spring Boot application.properties 文件的相关部分不起作用:
server.context-path=/myapp
server.port=8443
server.ssl.enabled=true
server.use-forward-headers=true
server.ssl.protocol=TLS
server.ssl.client-auth=need
server.ssl.key-alias=myalias
server.ssl.key-store=/path/to/mykeystore.jks
server.ssl.key-store-password=mypassword
server.ssl.key-password=mypassword
server.ssl.trust-store=/path/to/mykeystore.jks
server.ssl.trust-store-password=mypassword
server.tomcat.remote-ip-header=x-forwarded-for
server.tomcat.port-header=x-forwarded-port
请注意,直接访问应用程序时(即请求https://myapp.company.tld:12345/myapp)它工作得很好,但使用反向代理(即https://proxy-load-balancer.company.tld: 12345/myapp ) 抛出上述错误。
端口差异(12345 与配置的 8443)是由于中间 Docker 层:反向代理和应用程序都在容器中运行,并且它们的开放端口(Apache 为 443,Tomcat/Spring Boot 为 8443)映射到不同的端口,即 12345。