Nginx 的配置指令

来源:https://www.cnblogs.com/iziyang/archive/2020/04/07/12651234.html
-Advertisement-
Play Games

我們已經瞭解了 Nginx 的基本命令和架構原理,下麵該到最讓人頭疼也是最不容易理解的部分了,那就是 nginx.conf 這個配置文件,下麵從 Nginx 的指令開始,一步步來講解 Nginx 的配置。 Nginx 指令 先來看一個典型的 Nginx 配置文件示例。 從上面可以看到,這個配置文件中 ...


我們已經瞭解了 Nginx 的基本命令和架構原理,下麵該到最讓人頭疼也是最不容易理解的部分了,那就是 nginx.conf 這個配置文件,下麵從 Nginx 的指令開始,一步步來講解 Nginx 的配置。

Nginx 指令

先來看一個典型的 Nginx 配置文件示例。

main
http {
	upstream { … }
	split_clients {…}
	map {…}
	geo {…}
	server {
		if () {…}
		location {
			limit_except {…}
		}
		location {
			location {
			}
		}
	}
	server {
	}
}

從上面可以看到,這個配置文件中包含了多個指令塊,有些指令塊還是重覆的,那麼這在 Nginx 中是一個什麼樣的規則?接下來會慢慢介紹。

指令塊的嵌套

在 Nginx 配置文件中,指令塊是可以互相嵌套的,例如上面的示例,http 塊中可以包含多個 server 塊,server 塊中還會包含多個 location 塊,每一個塊中都有相應的指令。

而每一個指令都有 Context 上下文,也就是生效的環境,這在 Nginx 的官方文檔中說的很清楚,例如下麵的兩條指令,Context 中都表明瞭各自可以生效的環境,access_log 指令可以在多個上下文中生效:

Syntax:  access_log path [format [buffer=size] [gzip[=level]] [flush=time] [if=condition]];
		     access_log off;
Default: access_log logs/access.log combined; 
Context: http, server, location, if in location, limit_except

Syntax:  log_format name [escape=default|json|none] string ...;
Default: log_format combined "..."; 
Context: http

指令的合併

在 Nginx 中,指令分為兩種,一種是值指令,一種是動作類指令:

  • 值指令:存儲配置項的值,是用來配置某一個配置項的
    • 可以合併
    • 示例
      • root
      • access_log
      • gzip
  • 動作類指令:指定行為動作,往往表示接下來要做一件事情
    • 不可以合併
    • 示例
      • rewrit
      • proxy_pass
    • 生效階段
      • server_rewrite 階段
      • rewrite 階段
      • content 階段

這裡面的示例以及生效階段,後面都還會詳細講,這裡可以不用過多關註,既然指令分為兩種,那麼就有不同的繼承規則,下麵就來說一下。

值指令的繼承規則

例如下麵的配置文件,這裡面在 server 塊和 location 塊中都配置了 root 指令,Nginx 的繼承規則如下:

  • 子配置不存在時,直接使用父配置塊的指令
  • 子配置存在時,覆蓋父配置塊
server {
	listen 8080;
	root /home/geek/nginx/html;
	access_log logs/geek.access.log main;
	location /test {
		root /home/geek/nginx/test;
		access_log logs/access.test.log main;
	}
	location /dlib {
		alias dlib/;
	}
	location / {
	}

根據上面這兩條規則,第一個 location 使用自家的 root 指令,後面兩個 location 則使用 server 塊的 root 指令。這和編程語言中變數的作用域也是類似的,作用域更小的變數優先順序往往更高,Nginx 的指令也是一樣。

文檔中沒有的指令如何判斷生效範圍

對於很多第三方模塊,很可能文檔並不完善,這時候需要通過源碼來查看指令的生效範圍。需要明確下麵幾個問題:

  1. 指令在哪個塊下生效?
  2. 指令允許出現在哪些塊下?

這兩個問題是在源碼中定義的,例如:

static ngx_command_t  ngx_http_core_commands[] = {

    { ngx_string("variables_hash_max_size"),
      NGX_HTTP_MAIN_CONF|NGX_CONF_TAKE1,
      ngx_conf_set_num_slot,
      NGX_HTTP_MAIN_CONF_OFFSET,
      offsetof(ngx_http_core_main_conf_t, variables_hash_max_size),
      NULL },
    ......

從上面第三行可以看到,variables_hash_max_size 指令是在 main 塊下生效的。

還會有兩個回調方法:

  • 在 server 塊生效,從 http 向 server 合併
    • char *(*merge_srv_conf)(ngx_conf_t*cf, void *prev, void *conf);
  • 向 location 合併
    • char *(*merge_loc_conf)(ngx_conf_t*cf, void *prev, void *conf);

例如:

static ngx_http_module_t  ngx_http_core_module_ctx = {
    ngx_http_core_preconfiguration,        /* preconfiguration */
    ngx_http_core_postconfiguration,       /* postconfiguration */

    ngx_http_core_create_main_conf,        /* create main configuration */
    ngx_http_core_init_main_conf,          /* init main configuration */

    ngx_http_core_create_srv_conf,         /* create server configuration */
    ngx_http_core_merge_srv_conf,          /* merge server configuration */

    ngx_http_core_create_loc_conf,         /* create location configuration */
    ngx_http_core_merge_loc_conf           /* merge location configuration */
};

ngx_http_module_t 這個結構體裡面,定義了很多回調方法,最後一個 ngx_http_core_merge_loc_conf 方法,就是制定合併規則的。這個方法定義了兩個參數,一個是父配置,一個是子配置:

static char *ngx_http_core_merge_loc_conf(ngx_conf_t *cf, void *parent, void *child)
{
    ngx_http_core_loc_conf_t *prev = parent;
    ngx_http_core_loc_conf_t *conf = child;

    ngx_uint_t        i;
    ngx_hash_key_t   *type;
    ngx_hash_init_t   types_hash;

    if (conf->root.data == NULL) {
......

這個方法表明瞭從父配置向子配置合併。

listen 指令的用法

listen 指令在 server 塊中生效,用來配置監聽哪些埠,由這些埠來處理請求。listen 指令的配置如下:

如示例所示,listen 指令可以監聽的類型有多種,可以配置監聽地址和埠,也可以是僅地址和僅埠,還可以僅監聽 IPv6 等等。

究竟是哪個 server 來處理請求

server_name 指令的用法

一個指令:server_name

server_name 指令是用來配置究竟是哪個 server 來處理我們的請求的。有時候,一個 server_name 中可能會有多個功能變數名稱,這時候是如何選擇的呢?

  1. server_name 指令後可以跟多個功能變數名稱,第一個是主功能變數名稱,多個功能變數名稱之間空格分隔
  2. 泛功能變數名稱:僅支持在最前或最後加 *,例如:server_name *.taohui.tech
  3. 正則表達式匹配:server_name www.taohui.tech ~^www\d+\.taohui\.tech$;

當 server_name 指令後有多個功能變數名稱時,會有一個 server_name_in_redirect 的配置,這個配置預設關閉,它使用來控制功能變數名稱重定向的,也就是這個配置開啟之後,請求過來會重定向到主功能變數名稱訪問。

Syntax  server_name_in_redirect on | off;
Default server_name_in_redirect off; 
Context http, server, location
  1. 還可以用正則表達式創建變數

    • # 使用 $1/$2 的方式引用變數
      server { 
      	server_name ~^(www\.)?(.+)$; 
      	location / { root /sites/$2; } 
      }
      
    • # 還可以通過加一個 ?<> 的方式來命名變數
      server { 
      	server_name ~^(www\.)?(?<domain>.+)$;
      	location / { root /sites/$domain; } 
      }
      
  2. 特殊的配置規則

    • .test.tech 可以匹配 test.tech *.test.tech
    • _ 匹配所有功能變數名稱請求
    • "" 匹配沒有傳遞 host 頭部的請求

server 匹配的順序

  1. 精確匹配(與順序無關)
  2. * 在前的泛功能變數名稱(與順序無關)
  3. * 在後的泛功能變數名稱(與順序無關)
  4. 按文件中的順序匹配正則表達式功能變數名稱
  5. default server
    • 第 1 個
    • listen 指定 default

這裡面 default server 有兩種指定方式,假如沒有配置 default server,那麼第一個 server 塊就會成為 default server,如果 listen 中配置了 default,那麼就會由配置的塊進行處理。

關註公眾號回覆 Nginx 領取知識圖譜

關註公眾號回覆 Nginx 領取知識圖譜


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • CPU使用率 Linux 通過 /proc 虛擬文件系統,向用戶空間提供了系統內部狀態的信息,而 /proc/stat 提供的就是系統的 CPU 和任務統計信息 proc process information pseudo file system 查詢 man proc 關鍵指標常用參數 user ...
  • 更多電腦使用技巧可以訪問 "https://xiaoheidiannao.com" 查看哦! "Vim" 是Linux上的文本編輯工具,對於用習慣了 "Vim" 的人來說,肯定也想在Windows上使用 "Vim" ,至少我是這麼想的。雖然也有Windows版的 "Vim" ,但是在 "Word" ...
  • 本文分成入門篇和基礎篇。基礎篇包括變數、字元串處理、數學運算三部分。基礎篇包括流控制、函數和函數庫三部分。主要是基於例子進行講解,其中有 4 個複雜一點的腳本,看懂了也就入門了。 ...
  • 1. 讓外設工作起來 只要給相應的控制器中的寄存器發一個指令 向設備控制器的寄存器寫不就可以了嗎? 需要查寄存器地址、內容的格式和語義、操作系統需要給用戶提供一個簡單視圖 文件視圖 ,這樣方便 總的來說就是: 1. 形成文件視圖 2. 發出out指令 3. 形成中斷處理 中斷處理:當CPU(中央處理 ...
  • 補充 /etc/hostname :CenOS7主機名配置文件 /etc/sysconfig/network C6主機名配置文件 修改主機名 永久生效 臨時改一下 /etc/sysctl.conf Linux內核參數信息文件※※※※※ 調整Linux系統、優化需要配置這個文件 sysctl p 讓修 ...
  • 隨著互聯網+物聯網進程的加快,視頻監控應用領域變得越來越廣泛,其中海康威視 大華等品牌的攝像頭頻繁出現在視野中。由於去年也實現過智慧工地項目上的視頻監控方案,加上當今直播趨勢不減。現在總結一下: 緣由:是1對N 點對多的直播方式, 一般都是採用伺服器轉發,所以此處不考慮WebRTC這種端對端的方式, ...
  • pc開機時,在進入系統之前,要先進入的磁碟里安裝了grub開機引導的區域,如果是單系統一般不會有問題,但若是多系統像win+ubuntu或者ubuntu+ubuntu等,有時會出現grub引導程式損壞,或者其主引導所依賴的邏輯順序不是你想要的 這裡舉個極端一些的慄子:一開始在本地磁碟安裝了win+u ...
  • 一 資源管理 1.1 資源調度機制 對於Kubernetes資源,有兩個重要參數:CPU Request與Memory Request。 通常在定義Pod時並沒有定義這兩個參數,此時Kubernetes會認為該Pod所需的資源很少,並可以將其調度到任何可用的Node上。因此,當集群中的計算資源不很充 ...
一周排行
    -Advertisement-
    Play Games
  • 示例項目結構 在 Visual Studio 中創建一個 WinForms 應用程式後,項目結構如下所示: MyWinFormsApp/ │ ├───Properties/ │ └───Settings.settings │ ├───bin/ │ ├───Debug/ │ └───Release/ ...
  • [STAThread] 特性用於需要與 COM 組件交互的應用程式,尤其是依賴單線程模型(如 Windows Forms 應用程式)的組件。在 STA 模式下,線程擁有自己的消息迴圈,這對於處理用戶界面和某些 COM 組件是必要的。 [STAThread] static void Main(stri ...
  • 在WinForm中使用全局異常捕獲處理 在WinForm應用程式中,全局異常捕獲是確保程式穩定性的關鍵。通過在Program類的Main方法中設置全局異常處理,可以有效地捕獲並處理未預見的異常,從而避免程式崩潰。 註冊全局異常事件 [STAThread] static void Main() { / ...
  • 前言 給大家推薦一款開源的 Winform 控制項庫,可以幫助我們開發更加美觀、漂亮的 WinForm 界面。 項目介紹 SunnyUI.NET 是一個基於 .NET Framework 4.0+、.NET 6、.NET 7 和 .NET 8 的 WinForm 開源控制項庫,同時也提供了工具類庫、擴展 ...
  • 說明 該文章是屬於OverallAuth2.0系列文章,每周更新一篇該系列文章(從0到1完成系統開發)。 該系統文章,我會儘量說的非常詳細,做到不管新手、老手都能看懂。 說明:OverallAuth2.0 是一個簡單、易懂、功能強大的許可權+可視化流程管理系統。 有興趣的朋友,請關註我吧(*^▽^*) ...
  • 一、下載安裝 1.下載git 必須先下載並安裝git,再TortoiseGit下載安裝 git安裝參考教程:https://blog.csdn.net/mukes/article/details/115693833 2.TortoiseGit下載與安裝 TortoiseGit,Git客戶端,32/6 ...
  • 前言 在項目開發過程中,理解數據結構和演算法如同掌握蓋房子的秘訣。演算法不僅能幫助我們編寫高效、優質的代碼,還能解決項目中遇到的各種難題。 給大家推薦一個支持C#的開源免費、新手友好的數據結構與演算法入門教程:Hello演算法。 項目介紹 《Hello Algo》是一本開源免費、新手友好的數據結構與演算法入門 ...
  • 1.生成單個Proto.bat內容 @rem Copyright 2016, Google Inc. @rem All rights reserved. @rem @rem Redistribution and use in source and binary forms, with or with ...
  • 一:背景 1. 講故事 前段時間有位朋友找到我,說他的窗體程式在客戶這邊出現了卡死,讓我幫忙看下怎麼回事?dump也生成了,既然有dump了那就上 windbg 分析吧。 二:WinDbg 分析 1. 為什麼會卡死 窗體程式的卡死,入口門檻很低,後續往下分析就不一定了,不管怎麼說先用 !clrsta ...
  • 前言 人工智慧時代,人臉識別技術已成為安全驗證、身份識別和用戶交互的關鍵工具。 給大家推薦一款.NET 開源提供了強大的人臉識別 API,工具不僅易於集成,還具備高效處理能力。 本文將介紹一款如何利用這些API,為我們的項目添加智能識別的亮點。 項目介紹 GitHub 上擁有 1.2k 星標的 C# ...