zoukankan      html  css  js  c++  java
  • 一个简单的php站点配置

    一个简单的php站点配置

     
    现在我们来看在一个典型的,简单的PHP站点中,nginx怎样为一个请求选择location来处理:
     
    server {
        listen      80;
        server_name example.org www.example.org;
        root        /data/www;
     
        location / {
            index   index.html index.php;
        }
     
        location ~* .(gif|jpg|png)$ {
            expires 30d;
        }
     
        location ~ .php$ {
            fastcgi_pass  localhost:9000;
            fastcgi_param SCRIPT_FILENAME
                          $document_root$fastcgi_script_name;
            include       fastcgi_params;
        }
    }
    首先,nginx使用前缀匹配找出最准确的location,这一步nginx会忽略location在配置文件出现的顺序。上面的配置中,唯一的前缀匹 配location是"/",而且因为它可以匹配任意的请求,所以被作为最后一个选择。接着,nginx继续按照配置中的顺序依次匹配正则表达式的 location,匹配到第一个正则表达式后停止搜索。匹配到的location将被使用。如果没有匹配到正则表达式的location,则使用刚刚找到 的最准确的前缀匹配的location。
     
    请注意所有location匹配测试只使用请求的URI部分,而不使用参数部分。这是因为写参数的方法很多,比如:
     
    /index.php?user=john&page=1
    /index.php?page=1&user=john
    除此以外,任何人在请求串中都可以随意添加字符串:
     
    /index.php?page=1&something+else&user=john
    现在让我们来看使用上面的配置,请求是怎样被处理的:
     
    请求"/logo.gif"首先匹配上location "/",然后匹配上正则表达式".(gif|jpg|png)$"。因此,它将被后者处理。根据"root /data/www"指令,nginx将请求映射到文件/data/www/logo.gif",并发送这个文件到客户端。
    请求"/index.php"首先也匹配上location "/",然后匹配上正则表达式".(php)$"。 因此,它将被后者处理,进而被发送到监听在localhost:9000的FastCGI服务器。fastcgi_param指令将FastCGI的参数 SCRIPT_FILENAME的值设置为"/data/www/index.php",接着FastCGI服务器执行这个文件。变 量$document_root等于root指令设置的值,变量$fastcgi_script_name的值是请求的 uri,"/index.php"。
    请求"/about.html"仅能匹配上location "/",因此,它将使用此location进行处理。根据"root /data/www"指令,nginx将请求映射到文件"/data/www/about.html",并发送这个文件到客户端。
    请求"/"的处理更为复杂。它仅能匹配上location "/",因此,它将使用此location进行处理。然后,index指令使用它的参数和"root /data/www"指令所组成的文件路径来检测对应的文件是否存在。如果文件/data/www/index.html不存在,而/data/www /index.php存在,此指令将执行一次内部重定向到"/index.php",接着nginx将重新寻找匹配"/index.php"的 location,就好像这次请求是从客户端发过来一样。正如我们之前看到的那样,这个重定向的请求最终交给FastCGI服务器来处理。
  • 相关阅读:
    HDU Ignatius and the Princess III (母函数)
    HDU 1014 Uniform Generator
    HDU 1013 Digital Roots
    HDU u Calculate e
    HDU 1005 Number Sequence 找规律
    Vijos 送给圣诞夜的极光(bfs)
    HDU Sum Problem (一道神坑的水题)
    Vijos CoVH之再破难关(搜索+hash)
    VIjos 晴天小猪历险记之Number (搜索+链表hash)
    Vijos 有根树的同构问题【字符串---最小表示法】
  • 原文地址:https://www.cnblogs.com/wodetian/p/5658469.html
Copyright © 2011-2022 走看看