Converting rewrite rules
转换重写规则
- 转换Mongrel规则
重定向到主站点
在共享主机生活期间,只
使用Apache的.htaccess文件配置所有内容的
用户通常会翻译以下规则:
RewriteCond %{HTTP_HOST} example.org
RewriteRule (.*) http://www.example.org$1
如下:
server {
listen 80;
server_name www.example.org example.org;
if ($http_host = example.org) {
rewrite (.*) http://www.example.org$1;
}
...
}
这是一种错误,麻烦,无效的方式。正确的方法是定义一个单独的服务器example.org
:
server {
listen 80;
server_name example.org;
return 301 http://www.example.org$request_uri;
}
server {
listen 80;
server_name www.example.org;
...
}
在0.9.1之前的版本中,可以通过以下方式进行重定向:rewrite ^ http://www.example.org$request_uri ?;
另一个例子。除了“颠倒”逻辑“之外都不是example.com与www.example.com”:
RewriteCond %{HTTP_HOST} !example.com
RewriteCond %{HTTP_HOST} !www.example.com
RewriteRule (.*) http://www.example.com$1
人们应该简单地定义example.com
,www.example.com
和“其他”:
server {
listen 80;
server_name example.com www.example.com;
...
}
server {
listen 80 default_server;
server_name _;
return 301 http://example.com$request_uri;
}
在0.9.1之前的版本中,重定向可以通过以下方式进行:rewrite ^ http://example.com$request_uri ?;
转换Mongrel规则
典型的Mongrel规则:
DocumentRoot /var/www/myapp.com/current/public
RewriteCond %{DOCUMENT_ROOT}/system/maintenance.html -f
RewriteCond %{SCRIPT_FILENAME} !maintenance.html
RewriteRule ^.*$ %{DOCUMENT_ROOT}/system/maintenance.html [L]
RewriteCond %{REQUEST_FILENAME} -f
RewriteRule ^(.*)$ $1 [QSA,L]
RewriteCond %{REQUEST_FILENAME}/index.html -f
RewriteRule ^(.*)$ $1/index.html [QSA,L]
RewriteCond %{REQUEST_FILENAME}.html -f
RewriteRule ^(.*)$ $1.html [QSA,L]
RewriteRule ^/(.*)$ balancer://mongrel_cluster%{REQUEST_URI} [P,QSA,L]
应该转换为
location / {
root /var/www/myapp.com/current/public;
try_files /system/maintenance.html
$uri $uri/index.html $uri.html
@mongrel;
}
location @mongrel {
proxy_pass http://mongrel;
}