Ubuntu Nginx-重写文件夹的规则
我的VPS运行在Ubuntu Nginx-重写文件夹的规则,ubuntu,nginx,url-rewriting,Ubuntu,Nginx,Url Rewriting,我的VPS运行在Ubuntu+Nginx上 可通过以下浏览器访问:example.com 现在,我想在/var/www/html/中创建两个文件夹:laravel和magento,以便这两个位置分别承载不同的应用程序,相应地,magento和laravel: example.com/laravel/访问laravel应用程序 example.com/magento/访问magento商店 请告知我如何在/etx/Nginx/sites available/default中设置Nginx重写规
Ubuntu
+Nginx
上
可通过以下浏览器访问:example.com
现在,我想在/var/www/html/
中创建两个文件夹:laravel
和magento
,以便这两个位置分别承载不同的应用程序,相应地,magento和laravel:
- example.com/laravel/访问laravel应用程序
- example.com/magento/访问magento商店
/etx/Nginx/sites available/default
中设置Nginx重写规则以实现此目的
或者也许有其他方法来实现这一点
**编辑**
etc/nginx/sites-available/default:
server {
listen 80;
server_name xx.xx.xx.xx;
location /laravel/ {
root /var/www/html;
try_files $uri $uri/ /index.php?$query_string;
}
location /2.2.1/ {
set $MAGE_ROOT /var/www/html/2.2.1;
include /var/www/html/2.2.1/nginx.conf.sample;
}
}
您描述的行为将是添加这些子目录后的默认行为。假设根目录已设置为
/var/www/html
,则在webroot中创建文件夹foo
将允许您浏览到example.com/foo/
,而无需任何进一步配置。如果您希望将其用作foo.example.com
或其他内容,则可能需要重写规则。这就是它的设置方式。文件夹laravel
和magento
已经在/var/www/html
中。我现在只需要分别为每个文件夹设置nginx重写规则。如果我正确理解了您的问题,您所期望的行为已经实现。如果您需要针对laravel/
或magento/
目录添加进一步的重写,您可以为它们使用位置
块,并在那里添加重写规则。有关一些示例,请参见。你想在这里添加什么具体的行为吗?请看我更新的帖子。附有etc/nginx/sites available/default
源代码。如您所见,有两个位置部分。laravel部分包括针对laravel的nginx规则。Magento 1包括Magento的规则(也附在附件中)。但它不起作用。谢谢从您目前发布的内容来看,我仍然无法确定问题的根源。假设您的主文档根是/var/www/html
,则location/laravel/
块中的root
指令是多余的。另外,假设Laravel目录是/var/www/html/Laravel/
,则该位置块应该是正确的。请求http://example.com/laravel/index.php
应该成功。Magento配置中有很多内容,但是我也没有看到明显的错误。可能您正在观察的错误行为的具体示例会有所帮助,或者您可能会在日志中发现任何错误。您正在描述的行为将是添加这些子目录后的默认行为。假设根目录已设置为/var/www/html
,则在webroot中创建文件夹foo
将允许您浏览到example.com/foo/
,而无需任何进一步配置。如果您希望将其用作foo.example.com
或其他内容,则可能需要重写规则。这就是它的设置方式。文件夹laravel
和magento
已经在/var/www/html
中。我现在只需要分别为每个文件夹设置nginx重写规则。如果我正确理解了您的问题,您所期望的行为已经实现。如果您需要针对laravel/
或magento/
目录添加进一步的重写,您可以为它们使用位置
块,并在那里添加重写规则。有关一些示例,请参见。你想在这里添加什么具体的行为吗?请看我更新的帖子。附有etc/nginx/sites available/default
源代码。如您所见,有两个位置部分。laravel部分包括针对laravel的nginx规则。Magento 1包括Magento的规则(也附在附件中)。但它不起作用。谢谢从您目前发布的内容来看,我仍然无法确定问题的根源。假设您的主文档根是/var/www/html
,则location/laravel/
块中的root
指令是多余的。另外,假设Laravel目录是/var/www/html/Laravel/
,则该位置块应该是正确的。请求http://example.com/laravel/index.php
应该成功。Magento配置中有很多内容,但是我也没有看到明显的错误。也许您正在观察的错误行为的具体示例会有所帮助,或者您可能会在日志中发现任何错误。
/var/www/html/2.2.1/nginx.conf.sample
set $MAGE_ROOT /var/www/html/2.2.1;
root $MAGE_ROOT/pub;
index index.php;
autoindex off;
charset UTF-8;
error_page 404 403 = /errors/404.php;
#add_header "X-UA-Compatible" "IE=Edge";
# PHP entry point for setup application
location ~* ^/setup($|/) {
root $MAGE_ROOT;
location ~ ^/setup/index.php {
fastcgi_pass fastcgi_backend;
fastcgi_param PHP_FLAG "session.auto_start=off \n suhosin.session.cryptua=off";
fastcgi_param PHP_VALUE "memory_limit=7G \n max_execution_time=1800";
fastcgi_read_timeout 600s;
fastcgi_connect_timeout 600s;
fastcgi_index index.php;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
include fastcgi_params;
}
location ~ ^/setup/(?!pub/). {
deny all;
}
location ~ ^/setup/pub/ {
add_header X-Frame-Options "SAMEORIGIN";
}
}
# PHP entry point for update application
location ~* ^/update($|/) {
root $MAGE_ROOT;
location ~ ^/update/index.php {
fastcgi_split_path_info ^(/update/index.php)(/.+)$;
fastcgi_pass fastcgi_backend;
fastcgi_index index.php;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
fastcgi_param PATH_INFO $fastcgi_path_info;
include fastcgi_params;
}
# Deny everything but index.php
location ~ ^/update/(?!pub/). {
deny all;
}
location ~ ^/update/pub/ {
add_header X-Frame-Options "SAMEORIGIN";
}
}
location / {
try_files $uri $uri/ /index.php$is_args$args;
}
location /pub/ {
location ~ ^/pub/media/(downloadable|customer|import|theme_customization/.*\.xml) {
deny all;
}
alias $MAGE_ROOT/pub/;
add_header X-Frame-Options "SAMEORIGIN";
}
location /static/ {
# Uncomment the following line in production mode
# expires max;
# Remove signature of the static files that is used to overcome the browser cache
location ~ ^/static/version {
rewrite ^/static/(version\d*/)?(.*)$ /static/$2 last;
}
location ~* \.(ico|jpg|jpeg|png|gif|svg|js|css|swf|eot|ttf|otf|woff|woff2)$ {
add_header Cache-Control "public";
add_header X-Frame-Options "SAMEORIGIN";
expires +1y;
if (!-f $request_filename) {
rewrite ^/static/?(.*)$ /static.php?resource=$1 last;
}
}
location ~* \.(zip|gz|gzip|bz2|csv|xml)$ {
add_header Cache-Control "no-store";
add_header X-Frame-Options "SAMEORIGIN";
expires off;
if (!-f $request_filename) {
rewrite ^/static/?(.*)$ /static.php?resource=$1 last;
}
}
if (!-f $request_filename) {
rewrite ^/static/?(.*)$ /static.php?resource=$1 last;
}
add_header X-Frame-Options "SAMEORIGIN";
}
location /media/ {
try_files $uri $uri/ /get.php$is_args$args;
location ~ ^/media/theme_customization/.*\.xml {
deny all;
}
location ~* \.(ico|jpg|jpeg|png|gif|svg|js|css|swf|eot|ttf|otf|woff|woff2)$ {
add_header Cache-Control "public";
add_header X-Frame-Options "SAMEORIGIN";
expires +1y;
try_files $uri $uri/ /get.php$is_args$args;
}
location ~* \.(zip|gz|gzip|bz2|csv|xml)$ {
add_header Cache-Control "no-store";
add_header X-Frame-Options "SAMEORIGIN";
expires off;
try_files $uri $uri/ /get.php$is_args$args;
}
add_header X-Frame-Options "SAMEORIGIN";
}
location /media/customer/ {
deny all;
}
location /media/downloadable/ {
deny all;
}
location /media/import/ {
deny all;
}
# PHP entry point for main application
location ~ (index|get|static|report|404|503)\.php$ {
try_files $uri =404;
fastcgi_pass fastcgi_backend;
fastcgi_buffers 1024 4k;
fastcgi_param PHP_FLAG "session.auto_start=off \n suhosin.session.cryptua=off";
fastcgi_param PHP_VALUE "memory_limit=7G \n max_execution_time=18000";
fastcgi_read_timeout 600s;
fastcgi_connect_timeout 600s;
fastcgi_index index.php;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
include fastcgi_params;
}
gzip on;
gzip_disable "msie6";
gzip_comp_level 6;
gzip_min_length 1100;
gzip_buffers 16 8k;
gzip_proxied any;
gzip_types
text/plain
text/css
text/js
text/xml
text/javascript
application/javascript
application/x-javascript
application/json
application/xml
application/xml+rss
image/svg+xml;
gzip_vary on;
# Banned locations (only reached if the earlier PHP entry point regexes don't match)
location ~* (\.php$|\.htaccess$|\.git) {
deny all;
}