Am o configurare proxy inversă după cum urmează în Apache:
Server A cu adresa www.proxyserver.com/graphql este serverul proxy invers.
Se mapează la: Server B cu adresa example.com
Acest tip funcționează corect în mediul de dezvoltare.
De exemplu: atunci când serverul apelează o solicitare /graphql?query1=query1&query2=query2
apoi redirecționează către https://proxyserver.com/graphql?query1=query1&query2=query2
Dar în apache, nu funcționează. Sună http://example.com/graphql?query1=query1&query2=query2
Cum repar asta?
Proxy-ul meu invers este configurat după cum urmează pe Server 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>
și aceasta este configurația serverului 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>