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 / 问题 / 1074250
Accepted
Jetto Martínez
Jetto Martínez
Asked: 2021-08-12 09:30:15 +0800 CST2021-08-12 09:30:15 +0800 CST 2021-08-12 09:30:15 +0800 CST

设置 Apache 子域重定向到另一个子域

  • 772

我正在尝试设置两个子域,fora和bin domain.com。我使用了两个 .conf 文件,根据对 ServerName 和 ProxyPass 的更改,它们看起来几乎相同:

<VirtualHost *:80>
        ServerName a.domain.com #This was added as a try for a fix. 
        Redirect permanent /  https://a.domain.com/
</VirtualHost>

<VirtualHost *:443>

        ServerName a.domain.com
        ServerAdmin webmaster@localhost
        DocumentRoot /var/www/html/a

        ErrorLog ${APACHE_LOG_DIR}/error.log
        CustomLog ${APACHE_LOG_DIR}/access.log combined

        #SSL stuff

        #Proxies

        ProxyPass        /        https://a.domain.com:8444/
        ProxyPassReverse /        https://a.domain.com:8444/
        ProxyPass        /a/      https://a.domain.com:8444/
        ProxyPassReverse /a/      https://a.domain.com:8444/
        ProxyPass        /b/      https://b.domain.com:8445/
        ProxyPassReverse /b/      https://b.domain.com:8445/

</VirtualHost>

这是在我的测试环境中完成的,复制类似于当前生产的东西。在 /etc/hosts 中,我将a.domain.com和添加b.domain.com到 127.0.0.1。生产中的 DNS 记录了 whata.domain.com和b.domain.comare,这是相同的 IP(我也在我正在测试它的机器上做了这个)。

另请注意,我没有从他们的根目录中提供任何内容。我补充说,试图解决标题中所述的问题。不过,两个目录中都有一个简单的 html。

实际问题是什么?

简单地说,在尝试时a.domain.com,结果是来自 的 webapp localhost:8444,正如预期的那样。尝试b.domain.com的时候,结果也是localhost:8444,而不是localhost:8445。a.conf和都已b.conf启用,如果我禁用a.conf,那么我正确地得到localhost:8445. 如果我也尝试喜欢a.domain.com/b,重定向会解析回a.domain.com.

我已经阅读了几个问题和教程,其中大多数要么在我的配置中工作,要么添加 NameVirtualHost,我知道我的 Apache 版本不需要。我还在端口 80 中添加了一个 ServerName,因为我认为请求可能b被匹配,a.conf因为它们是相同的 IP,但这也不起作用。

我在这里想念什么?我似乎忽略了 mod_proxy 吗?如果可能的话,我想为每个 webapp 保留一个文件。谢谢!

这是在 Ubuntu 18.04.2、Apache 2.4(mod_proxy 和 mod_ssl)、Tomcat 9 上。您想要的任何其他信息,我会尽力提供。

更新

也试过这个配置。同样不受欢迎的结果。

<VirtualHost *:80>
        ServerAlias a.domain.com
        Redirect permanent /  https://a.domain.com/
</VirtualHost>

<VirtualHost *:443>

        ServerName a.domain.com
        ServerAdmin webmaster@localhost

        ErrorLog ${APACHE_LOG_DIR}/error.log
        CustomLog ${APACHE_LOG_DIR}/access.log combined

        #SSL stuff

        #Proxies

        Redirect /b https://b.domain.com

        <Location />
                ProxyPass               https://localhost:8444/
                ProxyPassReverse        https://localhost:8444/
        </Location>

        <Location /a>
                ProxyPass               https://localhost:8444/
                ProxyPassReverse        https://localhost:8444/
        </Location>

</VirtualHost>

更新

好的,我刚刚发现了一些非常烦人的事情。如果我使用浏览器输入a.domain.com或b.domain.com,它们都解析为a.domain.com。这就是我最初描述的问题。但如果尝试https://a.domain.com或https://b.domain.com,都解析到正确的服务器:ato8444和bto 8445。

因为这非常令人沮丧,所以我会在一段时间内停下来分析一下。

更新

经过长时间的刹车后,我尝试了一些其他的随机调整,只是为了看看发生了什么,但除了使用 HTTPS 时,再次没有按预期工作。我安装了 Postman 以查看请求中发送的内容,并发现在 Postman 中,HTTP 和 HTTPS 都正确使用了主机。更好/更糟:实际响应显示 和 的不同欢迎页面a.domain.com,b.domain.com这意味着当我使用 Postman 时,我的配置工作正常。

我认为所有这些考验可能只是缓存问题,但我选择的测试浏览器(Firefox 开发版)设置为不缓存内容。我将使用 curl 和其他浏览器检查响应。

subdomain mod-proxy apache-2.4
  • 1 1 个回答
  • 267 Views

1 个回答

  • Voted
  1. Best Answer
    Jetto Martínez
    2021-08-13T07:33:39+08:002021-08-13T07:33:39+08:00

    罪魁祸首:缓存。

    在某些时候,我的浏览器的配置发生了变化(也许是更新?)并且我拥有超过 3GB 的缓存,包括我试图设置为子域的测试站点。哎呀。

    清除缓存后,在访问我的 URL 时提示有关我的自签名证书的警报,正如预期的那样。接受风险后,我被重定向到正确的站点。这是通过使用b.domain.com而不添加协议。

    为了确保这能正常工作,我在所有其他 7 个浏览器中进行了测试(一定要确保),并在使用和不使用协议的情况下进行 curl,结果也是预期的。

    最后配置没问题。如果您需要通过子域代理到特定 Tomcat 实例的 Apache 服务器,我将在此处发布它,使用 proxy_mod 也会立即从端口 80 重定向到端口 433 。

    <VirtualHost *:80>
            ServerName a.domain.com
            Redirect permanent /  https://a.domain.com/
    </VirtualHost>
    
    <VirtualHost *:443>
            
            ServerName a.domain.com
            ServerAdmin [email protected]
    
            ErrorLog ${APACHE_LOG_DIR}/error.log
            CustomLog ${APACHE_LOG_DIR}/access.log combined
    
            #SSL stuff
    
            SSLEngine On
            SSLCertificateFile /etc/ssl/certs/DONT_USE_SELF_SIGNED.pem
            SSLCertificateKeyFile /etc/ssl/private/CERTS_IN_PRODUCTIve.key
            SSLVerifyClient none
    
            #Proxies
            ProxyRequests Off
            SSLProxyEngine on
            SSLProxyVerify none
            SSLProxyCheckPeerCN off
            SSLProxyCheckPeerName off
            SSLProxyCheckPeerExpire off
    
            #Redirections
            Redirect /b https://b.domain.com
    
            <Location />
                    ProxyPass               https://localhost:8444/
                    ProxyPassReverse        https://localhost:8444/
            </Location>
    
            <Location /a>
                    ProxyPass               https://localhost:8444/
                    ProxyPassReverse        https://localhost:8444/
            </Location>
    
    </VirtualHost>
    

    请注意 SSL 代理和 SSL 的设置是针对自签名证书的。如果您为生产环境实施此操作,请阅读每个文档的相关文档。另请注意,这是a.domain.com. for 的等价物b.domain.com完全相同,具有适当的 ServerName、ServerAlias、redirects、Location 和 localhost 端口。

    • 1

相关问题

  • Apache 上的子域不工作 - 找不到服务器

  • 如何使用域经销商 API 设置域屏蔽?

  • 如何在 IIS7 中创建子域?

  • 通配符 DNS 和子域

Sidebar

Stats

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

    新安装后 postgres 的默认超级用户用户名/密码是什么?

    • 5 个回答
  • Marko Smith

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

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

    • 9 个回答
  • Marko Smith

    什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同?

    • 3 个回答
  • Marko Smith

    如何确定bash变量是否为空?

    • 15 个回答
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +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