欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

詳解Nginx如何配置繼承模型

 更新時(shí)間:2018年07月13日 16:34:13   作者:夢(mèng)想_行人  
這篇文章主要介紹了詳解Nginx如何配置繼承模型,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧

要了解nginx的繼承模型,首先需要知道nginx使用多個(gè)配置塊進(jìn)行操作。 在nginx中,這樣的塊被稱為上下文,例如,放置在服務(wù)器上下文中的配置指令駐留在server { }塊中,就像放置在http上下文中的指令駐留在http { } 塊中一樣。

nginx中有6種可能的上下文,這里是從上到下的順序:

  •  Global.
  •  Http.
  •  Server.
  •  If.
  •  Location.
    •  Nested Location.
    •  If in location.
    •  limit_except.

默認(rèn)繼承模型是指令僅向下繼承。 從來(lái)沒(méi)有側(cè)身,絕對(duì)永遠(yuǎn)不會(huì)。 這包括您在內(nèi)部從一個(gè)位置重寫(xiě)請(qǐng)求到另一個(gè)位置的情況 - 第一個(gè)位置中的每個(gè)指令都被遺忘,只有第二個(gè)位置指令適用于位置上下文。 在繼承行為方面,nginx中有四種類型的配置指令:

  •   Normal指令 - 每個(gè)上下文一個(gè)值,例如:“root”或“index”。
  •   Array指令 - 每個(gè)上下文有多個(gè)值,例如:“access_log”或“fastcgi_param”
  •   Action指令 - 不只是配置的東西,例如:“rewrite”或“fastcgi_pass”
  •   try_files指令。

Normal指令是迄今為止最常見(jiàn)的指令,它遵循默認(rèn)的繼承模型而沒(méi)有任何意外。 讓我們看一個(gè)示例配置,顯示行為的情況。

server {
  root /home/user/public_html;
 
  location /app {
    root /usr/share; # This results in /usr/share/app
             # Full URI is ALWAYS appended.
  }
 
  location /app2 {
    // Server context root applies here.
  }
}

Array指令很像普通指令,因?yàn)樗鼈冏裱瓨?biāo)準(zhǔn)繼承模型,它始終向下繼承并替換在更高上下文中指定的任何指令。 可能令人困惑的是假設(shè)你添加到數(shù)組。Array 指令的行為是,如果在同一上下文中定義多個(gè)指令,則將添加到值,但如果在不同的上下文中定義多個(gè)指令,則較低的上下文將替換較高的上下文。 這意味著如果您希望它在多個(gè)上下文中存在,您有時(shí)需要雙重定義一個(gè)值。 這種情況的一個(gè)例子。

server {
  access_log /var/log/nginx/access.log;
  include fastcgi.conf;
 
  location ~ ^/calendar/.+\.php$ {
    access_log /var/log/nginx/php-requests.log; # If this executes then server context one never does.
 
    fastcgi_param ENV debug; # This *overwrites* the higher context array.
    include fastcgi.conf   # Therefore we include it in *this* context again.
  }
}

Action指令是它開(kāi)始變得有趣的地方。 它們被限制在一個(gè)上下文中并且永遠(yuǎn)不會(huì)向下繼承,但是它們可以在多個(gè)上下文中指定,并且在某些情況下將針對(duì)每個(gè)上下文執(zhí)行。 rewrite指令是一個(gè)action指令,允許在服務(wù)器和位置上下文中執(zhí)行兩個(gè)上下文。

server {
  rewrite ^/booking(.*) /calendar$1 permanent; # Always executes.
 
  location /calendar {
    rewrite ^ /index.php; # Can execute in addition to and does not replace server context rewrites.
  }
}

當(dāng)然,它并不那么簡(jiǎn)單。 在位置內(nèi)有三種可能的上下文,一個(gè)嵌套位置,一個(gè)if和limit_except。 指令的行為實(shí)際上完全取決于定義它的模塊。 如果在該上下文中允許,則所有normal和array指令都將正確繼承。 對(duì)于行動(dòng)指令,故事有點(diǎn)不同。 通常它們不會(huì)繼承到嵌套位置,但最終取決于模塊的預(yù)期,并且它可以在指令的基礎(chǔ)上有所不同。 這里沒(méi)有使用nginx文檔,所以你必須嘗試一下,看看nginx是否會(huì)抱怨。 為了更好地衡量,讓我們舉一個(gè)最常見(jiàn)的行為示例以及它如何影響重寫(xiě):

server {
  location /calendar {
    rewrite ^ /static.php; # Executes unless inner location matches.
 
    location ~ \.php$ {
      fastcgi_pass backend; # Outer location context rewrite is not executed.  
    }
  }
}

try_files指令與上面提到的每個(gè)其他操作指令大致相同,不同之處在于,如果放置在服務(wù)器上下文中,nginx實(shí)際上會(huì)創(chuàng)建一個(gè)偽位置,該位置是可能的最不具體的位置。 這意味著如果請(qǐng)求與定義的位置匹配,則不會(huì)執(zhí)行try_files指令。 這意味著如果您有l(wèi)ocation / defined,那么您有一個(gè)匹配每個(gè)可能請(qǐng)求的位置,因此try_files永遠(yuǎn)不會(huì)實(shí)際執(zhí)行。 因此,如果可能的話,始終將try_files放在位置上下文而不是服務(wù)器上下文中

server {
  try_files $uri /index.php; # This never executes.
 
  location / {
    # Whatever here, or empty.
  }
 
  location ~ \.php$ {
    # If this location executes then try_files still does not execute.
    # Even if location / did not exist.
  }
}

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • Nginx限制IP并發(fā)數(shù)與下載速度的方法

    Nginx限制IP并發(fā)數(shù)與下載速度的方法

    這篇文章主要介紹了Nginx中限制IP并發(fā)數(shù)與下載速度的方法,用到了limit_zone、limit_rate和limit_conn模塊,有需要的朋友參考下
    2014-01-01
  • Nginx和Apache幾種防盜鏈配置方法實(shí)例

    Nginx和Apache幾種防盜鏈配置方法實(shí)例

    這篇文章主要介紹了Nginx和Apache幾種防盜鏈配置方法實(shí)例,本文使用判斷來(lái)路的方法實(shí)現(xiàn)防盜鏈,分別給出Nginx和Apache配置實(shí)例,需要的朋友可以參考下
    2015-02-02
  • Nginx限流配置詳解

    Nginx限流配置詳解

    限流是服務(wù)降級(jí)的一種方式,通過(guò)限制系統(tǒng)的輸入和輸出流量以達(dá)到保護(hù)系統(tǒng)的目的,本文主要介紹了Nginx限流配置詳解,感興趣的可以了解一下
    2023-11-11
  • Nginx服務(wù)器中的location配置詳解

    Nginx服務(wù)器中的location配置詳解

    這篇文章主要介紹了Nginx服務(wù)器中的location配置詳解,包括location的匹配順序等基本概念,需要的朋友可以參考下
    2015-08-08
  • Nginx中常見(jiàn)header配置及修改

    Nginx中常見(jiàn)header配置及修改

    在nginx中,經(jīng)常需要因?yàn)楦鞣N原因,修改header,本文就來(lái)介紹一下header配置及修改,具有一定的參考價(jià)值,感興趣的可以了解一下
    2023-10-10
  • Nginx could not build the server_names_hash 錯(cuò)誤的解決辦法

    Nginx could not build the server_names_hash 錯(cuò)誤的解決辦法

    這篇文章主要介紹了Nginx could not build the server_names_hash 錯(cuò)誤的解決辦法,需要的朋友可以參考下
    2014-03-03
  • nginx配置location?root簡(jiǎn)單方法記錄

    nginx配置location?root簡(jiǎn)單方法記錄

    Location是Nginx中一個(gè)非常核心的配置,下面這篇文章主要給大家介紹了關(guān)于nginx配置location?root的相關(guān)資料,文中介紹的非常詳細(xì),需要的朋友可以參考下
    2023-12-12
  • 在Nginx服務(wù)器中配置針對(duì)TCP的負(fù)載均衡的方法

    在Nginx服務(wù)器中配置針對(duì)TCP的負(fù)載均衡的方法

    這篇文章主要介紹了在Nginx服務(wù)器中配置針對(duì)TCP的負(fù)載均衡的方法,另外還介紹了TCP負(fù)載均衡的執(zhí)行原理,需要的朋友可以參考下
    2015-12-12
  • 部署Nginx+Apache動(dòng)靜分離的實(shí)例詳解

    部署Nginx+Apache動(dòng)靜分離的實(shí)例詳解

    Nginx不僅能作為Web服務(wù)器,還具有反向代理、負(fù)載均衡和緩存的功能,這篇文章主要介紹了部署Nginx+Apache動(dòng)靜分離的實(shí)例代碼,需要的朋友可以參考下
    2019-12-12
  • nginx中配置sse的方法示例

    nginx中配置sse的方法示例

    本文主要介紹了nginx中配置sse的方法示例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2024-08-08

最新評(píng)論