如何在 apache 中处理代理调用

如何在 apache 中处理代理调用

我在 Apache 中有一个反向代理设置,如下所示:

服务器 A 的地址www.proxyserver.com/graphql是反向代理服务器。

它映射到:服务器 B,地址为 example.com

此类在开发环境中可以正常工作。

例如:当服务器调用请求时/graphql?query1=query1&query2=query2,它会重定向到https://proxyserver.com/graphql?query1=query1&query2=query2

但在 apache 中,它不起作用. 它调用http://example.com/graphql?query1=query1&query2=query2

我该如何解决?

我的反向代理在服务器 B 上配置如下(www.example.com):

<VirtualHost *:80>
    ServerAdmin [email protected]
    DocumentRoot /var/www/example.com/build
    ServerName example.com
    ServerAlias www.example.com
    ErrorLog ${APACHE_LOG_DIR}/error.log
    CustomLog ${APACHE_LOG_DIR}/access.log combined
    ProxyPreserveHost On
    ProxyPass "/graphql" "https://proxyserver.com/graphql"
    ProxyPassReverse "/graphql" "https://proxyserver.com/graphql"
</VirtualHost>

这是服务器 A 的配置

<IfModule mod_ssl.c>
    <VirtualHost *:443>
        ServerAdmin [email protected]
        DocumentRoot /etc/pub
        ServerName proxyserver.com
        ErrorLog logs/cezanno-error_log
        LimitRequestBody 104857600
        <Proxy "unix:/var/opt/remi/php73/run/php-fpm/php73-fpm.sock|fcgi://proxyserver.com">
            ProxySet timeout=100
        </Proxy>
        <FilesMatch \.(php|phar)$>
            SetHandler "proxy:fcgi://proxyserver.com"
        </FilesMatch>

        SSLCertificateFile /path/to/cert/directory/cert.pem
        SSLCertificateKeyFile /path/to/cert/directory/privkey.pem
        Include /etc/letsencrypt/options-ssl-apache.conf
        SSLCertificateChainFile /path/to/cert/directory/chain.pem
    </VirtualHost>
</IfModule>

相关内容