Сложность в том, что некоторым скриптам необходимо знать через какую схему они работают, http, или https. Таким образом они формируют ссылки, а иногда принудительно перенаправляют клиентов куда нужно. Из-за не верной настройки серверного ПО переадресация не может завершиться и браузер покажет нам ошибку ‘too many redirects’.
В статье рассмотрим две схемы:nginx (front1, server2) -> nginx (front2, server1) -> php-fpm (back, server1)nginx (front1, server2) -> nginx (front2, server1) -> apache (back, server1)
Первой рассмотрим схему с php-fpm:
nginx (front1, server2) -> nginx (front2, server1) -> php-fpm (back, server1)
На сервере nginx (front1, server2) у нас обязательно должны быть строки
| |
среди которых нам важна последняя.
На сервере nginx (front2, server1) в секцию http добавляем
| |
Если его добавить в любое другое место - получите следующую ошибку при перезапуске nginx:
| |
Если прописать просто $https вместо $fastcgi_https - получите следующую ошибку:
| |
Дело в том, что начиная с какой-то бородатой версии NginX имеет встроенную переменную $https, поэтому ее повторно использовать не получится.
Редактируем /etc/nginx/fastcgi_params:
Комментируем/удаляем:fastcgi_param HTTPS $https if_not_empty;
Добавляем:fastcgi_param HTTPS $fastcgi_https if_not_empty;
Проверяем конфигурацию nginxservice nginx configtest
перезагружаем конфигурациюservice nginx reload
Проверяем с помощью phpinfo, если видим в выводе \
| |
значит всё в порядке, скрипты будут работать корректно.
Рассмотрим вторую схему, когда вместо php-fpm используется apache:
nginx (front1, server2) -> nginx (front2, server1) -> apache (back, server1)
В таком случае конфигурация сервера nginx (front1, server2) идентична конфигурации выше, т.е. нам важно присутствие параметраproxy_set_header X-Forwarded-Proto $scheme;
В конфигурации сервера nginx (front2, server1) у нас скорее всего будут строки
| |
здесь комментируем, или удаляем последнюю строку, а вместо неё пишемproxy_set_header X-Forwarded-Proto $http_x_forwarded_proto;
После этого в phpinfo уже сейчас можно будет увидеть параметр \
| |
Добавляем в конфигурацию apache (back, server1) следующие строки
| |
должен быть подключен модуль setenvif_module, посмотреть можно с помощью ‘apache2ctl -M’.
К моему удивлению, после этого в phpinfo ничего не изменилось, я всё так же видел
| |
долго возился, но, как оказалось, скриптам этот параметр всё же передаётся и ссылки формируются правильно. Я на всякий случай убрал конструкцию из конфигурации apache, изменений в phpinfo не увидел, а вот скрипт стал формировать ссылки не правильно. Ещё думал над параметром X-Forwarded-Port, но, как оказалось, nginx не умеет передавать динамически используемый клиентом порт, он может передавать только тот порт, по которому соединяется со следующим сервером (бэкэндом).
Использованы материалы:
www.tech-notes.net
eurohoster.org
www.sonassi.com
forge.typo3.org