我提出了一个小问题,我们正在为新项目使用负载均衡器,但我们无法强制使用www。没有请求之间的重定向循环。
我们目前正在使用NGINX,并且要重定向的代码段如下:
# FORGE CONFIG (DOT NOT REMOVE!)
include forge-conf/mywebsite.com/before/*;
# FORGE CONFIG (DOT NOT REMOVE!)
include upstreams/mywebsite.com;
server {
listen 443 ssl;
listen [::]:443 ssl;
server_name .mywebsite.com;
if ($host !~* ^www\.){
rewrite ^(.*)$ https://www.mywebsite.com$1;
}
# FORGE SSL (DO NOT REMOVE!)
ssl_certificate /etc/nginx/ssl/mywebsite.com/225451/server.crt;
ssl_certificate_key /etc/nginx/ssl/mywebsite.com/225451/server.key;
ssl_protocols TLSv1 TLSv1.1 TLSv1.2;
charset utf-8;
access_log off;
error_log /var/log/nginx/mywebsite.com-error.log error;
# FORGE CONFIG (DOT NOT REMOVE!)
include forge-conf/mywebsite.com/server/*;
location / {
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proto $scheme;
proxy_set_header Host $http_host;
proxy_set_header X-NginX-Proxy true;
proxy_pass http://370308_app/;
proxy_redirect off;
# Handle Web Socket Connections
proxy_http_version 1.1;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection "upgrade";
}
}
# FORGE CONFIG (DOT NOT REMOVE!)
include forge-conf/mywebsite.com/after/*;
# FORGE CONFIG (DOT NOT REMOVE!)
include forge-conf/mywebsite.com/before/*;
server {
listen 80;
listen [::]:80;
server_name .mywebsite.com;
root /home/forge/mywebsite.com/public;
if ($host !~* ^www\.){
rewrite ^(.*)$ https://www.mywebsite.com$1;
}
# FORGE SSL (DO NOT REMOVE!)
# ssl_certificate;
# ssl_certificate_key;
ssl_protocols TLSv1 TLSv1.1 TLSv1.2;
ssl_ciphers 'ECDHE-RSA-AES128-GCM-SHA256:ECDHE-ECDSA-AES128-GCM-SHA256:ECDHE-RSA-AES256-GCM-SHA384:ECDHE-ECDSA-AES256-GCM-SHA384:DHE-RSA-AES128-GCM-SHA256:DHE-DSS-AES128-GCM-SHA256:kEDH+AESGCM:ECDHE-RSA-AES128-SHA256:ECDHE-ECDSA-AES128-SHA256:ECDHE-RSA-AES128-SHA:ECDHE-ECDSA-AES128-SHA:ECDHE-RSA-AES256-SHA384:ECDHE-ECDSA-AES256-SHA384:ECDHE-RSA-AES256-SHA:ECDHE-ECDSA-AES256-SHA:DHE-RSA-AES128-SHA256:DHE-RSA-AES128-SHA:DHE-DSS-AES128-SHA256:DHE-RSA-AES256-SHA256:DHE-DSS-AES256-SHA:DHE-RSA-AES256-SHA:AES128-GCM-SHA256:AES256-GCM-SHA384:AES128-SHA256:AES256-SHA256:AES128-SHA:AES256-SHA:AES:CAMELLIA:DES-CBC3-SHA:!aNULL:!eNULL:!EXPORT:!DES:!RC4:!MD5:!PSK:!aECDH:!EDH-DSS-DES-CBC3-SHA:!EDH-RSA-DES-CBC3-SHA:!KRB5-DES-CBC3-SHA';
ssl_prefer_server_ciphers on;
ssl_dhparam /etc/nginx/dhparams.pem;
add_header X-Frame-Options "SAMEORIGIN";
add_header X-XSS-Protection "1; mode=block";
add_header X-Content-Type-Options "nosniff";
index index.html index.htm index.php;
charset utf-8;
# FORGE CONFIG (DOT NOT REMOVE!)
include forge-conf/mywebsite.com/server/*;
location / {
try_files $uri $uri/ /index.php?$query_string;
}
location = /favicon.ico { access_log off; log_not_found off; }
location = /robots.txt { access_log off; log_not_found off; }
access_log off;
error_log /var/log/nginx/mywebsite.com-error.log error;
error_page 404 /index.php;
location ~ \.php$ {
fastcgi_split_path_info ^(.+\.php)(/.+)$;
fastcgi_pass unix:/var/run/php/php7.1-fpm.sock;
fastcgi_index index.php;
include fastcgi_params;
}
location ~ /\.(?!well-known).* {
deny all;
}
}
# FORGE CONFIG (DOT NOT REMOVE!)
include forge-conf/mywebsite.com/after/*;
事情是,通过这个配置,我只能从服务器获得重定向循环。
请帮助:D< 3
答案 0 :(得分:3)
我认为您提供的nginx片段不会导致重定向循环。
首先,您必须弄清楚它是否是实际重定向 - 在这些问题中,301 Moved Permanently
响应会在您的浏览器中缓存,然后您会看到缓存版本,而不是新鲜的之一。
随后,您必须弄清楚导致重定向循环的原因:
尝试为每个重定向指令添加唯一字符串,以查看哪一个会导致循环。
if ($host !~* ^www\.) {return 301 $scheme://www.$host/levelX$request_uri}
问问自己为什么一开始就有这么多的重定向指令 - 似乎没有太多合理的理由在前端负载均衡器上都有重定向指令,以及后端。
如果以上方法无法解决问题,那么您就知道重定向循环不是来自您提供的文件,而是您必须深入挖掘 - 它可能来自其他一些文件,可能是include
指令之一,或者www.example.com
的默认服务器在别处定义,重定向到example.com
,或者重定向可能在应用层完成。
答案 1 :(得分:3)
在写完先前的通用答案后,我Googled "FORGE CONFIG (DOT NOT REMOVE!)",这是第一个结果:
https://laracasts.com/discuss/channels/forge/forge-how-to-disable-nginx-default-redirection
在nginx / forge-conf / be106.net /之前/ redirect.conf文件中有这个简单的配置:
… server_name www.my-domain.net; return 301 $scheme://my-domain.net$request_uri; …
有一种简单的方法可以在不改变文件本身的情况下删除它(因为它看起来很糟糕)。
因此,似乎重定向是由您正在使用的应用程序引起的,因此,我们发现了最有可能导致循环的原因!
反过来,配置应用程序以避免上述循环的适当方法将超出StackOverflow的分数。
但是,作为一种解决方法:
考虑您是否确实需要负载均衡器级别的所有forge-conf
include
指令;随后,您可以伪造相应的域以传递给不会导致重定向的后端(前提是您删除了自己的冗余重定向):
- proxy_set_header Host $http_host;
+ proxy_set_header Host example.com;
请注意,forge-conf/example.com/before/redirect.conf
指令优先于您自己的.example.com
配置的原因是指令的顺序 - 您可能会移动/before/*
{{1}如果这样的举动有意义的话,那就是在你自己的配置之后。