首页 文章

这是Apache Tomcat之间的错误SSL连接吗?

提问于
浏览
3

我正在查看本指南,使用SSL设置tomcat apache:http://www.mulesoft.com/tcat/tomcat-ssl

在“何时使用SSL与Tomcat”一节下,它说:

“...换句话说,如果您使用Web服务器将Tomcat作为应用程序服务器或Tomcat servlet容器使用它,那么在大多数情况下,您应该让Web服务器充当所有SSL请求的代理”

由于我已经使用SSL设置了网络服务器,因此我决定保持懒惰 . 我用默认设置安装了tomcat,并启动了它 . 在我的httpd.conf中,我将所有80个流量重定向到443,然后将proxypass和proxypassreverse重定向到ajp://hostname.com:8009 . 我重新启动了httpd,它“似乎”通过ssl重定向到tomcat服务器 . 这完全被打破了还是我真的设法做了我想要的第一次去?任何测试建议都非常感谢 .

<VirtualHost *:80>
        ServerName hostname_DNS_alias.com
        Redirect / https://hostname_DNS_alias.com
</VirtualHost>

<VirtualHost *:443>
        SSLEngine On
        SSLCertificateFile /etc/pki/tls/certs/thecrt.crt
        SSLCertificateKeyFile /etc/pki/tls/private/thekey.key
        SSLCertificateChainFile /etc/pki/tls/certs/CA.crt
        ServerName hostname_DNS_alias.com
        DocumentRoot /var/www/html

        <Proxy *>
                AddDefaultCharset off
                Order deny,allow
                Allow from all
        </Proxy>

        ProxyPass          /    ajp://hostname.com:8009/
        ProxyPassReverse   /    ajp://hostname.com:8009/
</VirtualHost>

1 回答

  • 0

    我想你已经知道了,但你可以查看HTTPD和Tomcat上的访问日志来确认请求被代理 . 您应该在两个系统上都看到访问日志条目 .

    几个快速笔记......

    • 如评论中所述,您可以从Tomcat中删除HTTP连接器 . 但这不是必须的 . 有时为了测试目的而保持开放是很好的(即你可以直接点击服务器),或者你想在其上运行Manager应用程序 . 如果您确实保留它,特别是如果您使用它来运行Manager应用程序,您应该限制对它的访问 . 两种简单的方法是将HTTP连接器上的 address 属性设置为 localhost 或配置RemoteAddressFilter .

    • 请记住,从HTTPD服务器到Tomcat的AJP连接未加密(SSL在HTTPD处终止),因此您要确保流量永远不会通过不安全的网络(如Internet) .

    • 由于您已经在混合中使用了HTTPD,因此您也可以使用它来提供静态文件 . 如果将它们部署到文档根目录,则可以添加“ProxyPass!” . 指令将该路径排除在代理之外的Tomcat . 这将在请求上提供稍微减少的延迟,因为HTTPD确实需要从Tomcat获取静态文件 .

相关问题