I've got two options (return and rewrite) for redirection and I'm not sure which is recommended for performance, SEO, etc:
## Redirect from non-www to www
server {
server_name example.com;
# Option 1
return 301 $scheme://$host$request_uri;
# Option 2
rewrite ^ http://$host$request_uri? permanent;
}
## Default server config
server {
...
listen 192.168.1.1:80 default_server;
root /www;
server_name www.example.com;
Option 2 seems to work with curl but it's not redirecting when called by a browser and the return code is that of a temporary redirect despite the rewrite directive being set to permanent
:
curl -I example.com
HTTP/1.1 302 Moved Temporarily
Server: nginx
...
Location: http://www.example.com/
...
Your option 1:
Is exactly what you want.
Not sure why the
rewrite ^ http://$host$request_uri? permanent;
line would result in a 302 instead of 301. That's the proper syntax to force it to return a 301.Technically, you can use both options. They can work.
According to the NGINX documentation, use
return
if you can. It is simpler and faster because NGINX stops processing the request (and doesn't have to process a regex). More than that, you can specify a code in the 3xx series:If you have a scenario where you need to validate the URL with a regex or need to capture elements in the original URL (that are obviously not in a corresponding NGINX variable), then you should use
rewrite
. You must know thatrewrite
returns only code 301 or 302.You can read more about return and rewrite on the NGINX website.