Warning: file_get_contents(/data/phpspider/zhask/data//catemap/7/jsf/5.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Ubuntu Nginx-重写文件夹的规则_Ubuntu_Nginx_Url Rewriting - Fatal编程技术网

Ubuntu Nginx-重写文件夹的规则

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重写规

我的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重写规则以实现此目的

或者也许有其他方法来实现这一点

**编辑**

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;
}