主頁 > 軟體設計 > nginx常用配置筆記(反向代理、負載均衡、SSL配置、URL重寫等)

nginx常用配置筆記(反向代理、負載均衡、SSL配置、URL重寫等)

2021-10-20 08:10:32 軟體設計

1 nginx的核心功能及應用場景

  • 靜態資源服務器(靜態網站、靜態資源訪問)
  • 檔案服務器(搭配fastDFS可以搭建分布式檔案服務器)
  • 虛擬主機
  • 請求轉發
  • 反向代理
  • 負載均衡
  • URl請求rewrite
  • 軟防火墻

2 nginx安裝設定的核心組態檔及相關服務操作命令

2.1 檔案上傳下載命令:
# 從本地拷貝檔案到遠程服務器[需要指定拷貝的目的地檔案直接在路徑后面再跟上檔案的名稱就可以]

scp nginx-1.20.1.tar.gz root@116.64.151.39:/opt/packages

# 從遠程服務器拷貝檔案到本地[需要指定拷貝的目的地檔案直接在路徑后面再跟上檔案的名稱就可以]

scp root@www.runoob.com:/home/root/others/music /home/space/music/1.mp3 

# 拷貝檔案夾

scp -r www.runoob.com:/home/root/others/ /home/space/music/

**注意:**這個scp命令只能在linux系統下可以使用,一般都是安裝了linux作業系統的堡壘機或跳板機中使用,如果是windows,可以直接借助ftp客戶端工具進行檔案上傳下載

2.2 檔案解壓縮命令
# 檔案解壓縮命令
tar -zxf nginx-1.20.1.tar.gz
2.3 安裝命令
# 編譯命令[需要進入到nginx-1.20.1.tar.gz解壓檔案的根目錄下,configure可執行檔案在根目錄下]
./configure --prefix=/usr/local/software/nginx --error-log-path=/usr/local/software/nginx/logs/error.log --http-log-path=/usr/local/software/nginx/logs/access.log --with-http_gzip_static_module --http-client-body-temp-path=/usr/local/software/nginx/client --http-proxy-temp-path=/usr/local/software/nginx/proxy --http-fastcgi-temp-path=/usr/local/software/nginx/fastcgi --http-uwsgi-temp-path=/usr/local/software/nginx/uwsgi --http-scgi-temp-path=/usr/local/software/nginx/scgi --with-http_stub_status_module --with-http_ssl_module 

# 編譯命令
make

# 安裝命令
make install
2.4 nignx啟動、退出、重新加載組態檔的命令

需要先進入安裝好的目錄/usr/local/nginx/sbin【因為這里暫時還沒有配置環境變數】

# 沒有配置環境變數需要先進入到nginx的安裝目錄下的sbin目錄進行服務的啟動

#【默認nginx.conf啟動】
 
./nginx
 
#【指定組態檔啟動】

./nginx -c conf/nginx.conf

#【快速停止nginx服務】

./nginx -s stop

#【優雅關閉,在退出前完成已經接受的連接請求】

./nginx -s quit

#【重新加載配置】

./nginx -s reload 重新加載配置
2.5 nignx加入系統服務的關鍵組態檔

需要在/usr/lib/systemd/system目錄下創建一個組態檔nginx.service,添加內容如下:

[Unit]
Description=nginx -  web server
After=network.target remote-fs.target nss-lookup.target
  
[Service]
Type=forking
PIDFile=/usr/local/software/nginx/logs/nginx.pid
ExecStartPre=/usr/local/software/nginx/sbin/nginx -t -c /usr/local/software/nginx/conf/nginx.conf
ExecStart=/usr/local/software/nginx/sbin/nginx -c /usr/local/software/nginx/conf/nginx.conf
ExecReload=/usr/local/software/nginx/sbin/nginx -s reload
ExecStop=/usr/local/software/nginx/sbin/nginx -s stop
ExecQuit=/usr/local/software/nginx/sbin/nginx -s quit
PrivateTmp=true
  
[Install]
WantedBy=multi-user.target
2.6 重新加載系統服務命令
systemctl daemon-reload
2.6 通過系統服務設定開機自啟以及手動啟動、重啟、停止NGINX服務命令
# 啟動nginx

systemctl start nginx

systemctl start nginx.service

# 重啟nginx

systemctl restart nginx

systemctl restart nginx.service

# 停止nginx

systemctl stop nginx

systemctl stop nginx.service

# 查看nginx的運行狀態

systemctl status nginx.service

systemctl status nginx.service -l

2.7 加入或取消開機啟動

# 設定成開機自啟動

systemctl enable nginx.service

# 關閉開機自啟動

systemctl disable nginx.service

在這里插入圖片描述

2.8 防火墻相關命令

# 添加開放埠

firewall-cmd --zone=public --add-port=9000/tcp --permanent

# 查詢所有開放埠串列

firewall-cmd --list-ports

# 移除開放埠

firewall-cmd --zone=public --remove-port=9000/tcp --permanent

# 重新加載防火墻規則

firewall-cmd --reload

# 啟動防火墻

systemctl start firewalld.service

# 重啟防火墻

systemctl restart firewalld.service

# 關閉防火墻

systemctl stop firewalld.service

# 查看防火墻的運行狀態

systemctl status firewalld.service

systemctl status firewalld.service -l

安裝好nginx之后,修改組態檔下的server中監聽的埠為一個未被占用的埠,重新啟動nginx,通過i瀏覽器訪問http://服務器IP:埠【這里服務器IP就是安裝了nginx服務的機器的ip地址,如果是云服務器就是這臺機器的公網IP,埠就是剛才修改的組態檔的監聽埠】
在這里插入圖片描述
如上圖,則nginx的環境就搭建好了,下面就可以來玩一玩一些比較常見的配置操作了

3 nginx常用配置

nginx的核心配置都是在安裝目錄下的conf/nginx.conf檔案中進行配置的

3.1 偵聽埠

server {

# 標準HTTP協議

listen 80;

#  標準HTTPS協議

listen 443 ssl;

# HTTP2

listen 443 ssl http2;

# 使用IPv6偵聽80埠

listen [::]:80;

# 只使用IPv6偵聽80埠

listen [::]:80 ipv6only=on;

}
3.2 訪問日志配置

server {

# 相對或者絕對的日志檔案路徑【這里注意如果使用相對路徑的起始路徑默認是nginx的安裝目錄】

access_log /path/to/file.log;

# 是否開啟訪問日志【默認是開啟的】 

access_log on;

}
3.3 監聽的IP或者域名配置

server {

# 主機IP或者域名

server_name mydomain.com;

# 監聽多個IP或者域名時,使用空格進行分隔

# server_name mydomain.com www.mydomain.com;

# 監聽所有的域

server_name *.mydomain.com;

# 監聽所有的頂級域名

server_name mydomain.*;

# Listen to unspecified Hostnames (Listens to IP address itself)

server_name "";

}

3.4 靜態資源訪問配置
server {

	listen 80;

	server_name mydomain.com;

	location / {
	
		// 網站的靜態資源的訪問的根目錄在服務器上面的存放路徑
		
 		root /path/to/website;

	}
}
3.5 請求重定向
	server {
	
		listen 80;
		
		server_name www.mydoamin.com;
		
		# 當請求當前網站首頁時,將請求重定向到下面這個請求路徑上
		
		return 301 http://mydoamin.com$request_uri;
		
	}
	
	server {
	
		listen 80;
		
		server_name www.mydoamin.com;
		
		# 當請求網站指定的請求路徑時,將請求重定向到下面這個請求路徑上
		
		location /redirect-url {
		
			return 301 http://otherdomain.com;
			
		}
	}
3.6 反向代理

nginx的反向代理配置通過proxy_pass進行配置

	server {
	
		listen 80;
		
		server_name mydomain.com;
		
		# 下面這個location配置的含義就是主機下的80埠是,會將所有的請求的代理到 http://0.0.0.0:10000下進行處理
		
		location / {
		
			proxy_pass http://0.0.0.0:10000;
			
		}
		
	}

反向代理存在一個問題就是會默認代理重定向,導致服務端如果想要獲取請求端的請求頭資料資訊無法獲取,這時需要作如下配置,關閉代理重定向,設定代理請求頭

    server {
	
		listen 80;
		
		server_name mydomain.com;
		
		# 下面這個location配置的含義就是主機下的80埠是,會將所有的請求的代理到 http://0.0.0.0:10000下進行處理
		
		location / {
		        proxy_redirect off;
		        
                proxy_set_header Host $host;
                
                proxy_set_header X-Real-IP $remote_addr;
                
                proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
                
			    proxy_pass http://0.0.0.0:10000;
			
		}
		
	}

3.7 負載均衡
	# 負載均衡的組態檔下發如下: 定義一個app_request變數[可以任意命名,但是不能使用組態檔的關鍵字]代理多個服務端
	upstream app_request {
	
	 	server 0.0.0.0:10000;
	 	
		server 0.0.0.0:10001;
		
		server 116.131.73.102:8080;
		
	}
	
	server {
	
	listen 80;
	
	server_name mydomian.com;
	
	location / {
	
	 	# 配置了負載均衡之后,這里不能再使用某個后端服務,而是需要使用 負載均衡配置中使用的app_request變數,切記
	 	
		proxy_pass http://app_request ;
	
	}
	}
3.7 負載均衡權重配置【默認輪詢】
##### **weight(權重)**

# 指定輪詢幾率,weight和訪問比率成正比,用于后端服務器性能不均的情況,

upstream httpds {

	# down:表示當前的server暫時不參與負載

    server 127.0.0.1:8050       weight=10 down;
    
    # weight:默認為1.weight越大,負載的權重就越大,
    
    server 127.0.0.1:8060       weight=1;
    
    # backup: 其它所有的非backup機器down或者忙的時候,請求backup機器
        
     server 127.0.0.1:8060      weight=1 backup;
     
}

3.9 SSL協議配置
	server {
			
		# https協議默認使用443埠
			
		listen 443 ssl;

		# 偵聽域名
		
		server_name mydomain.com;

		# 開啟ssl協議
		
		ssl on;

		# 證書所在路徑【一般就放在組態檔nginx.conf同級目錄,其他自定義位置也可以】
		
		ssl_certificate /path/to/cert.pem;
		
		# 私鑰所在路徑【一般就放在組態檔nginx.conf同級目錄,其他自定義位置也可以】
		
		ssl_certificate_key /path/to/privatekey.pem;
		
		ssl_stapling on;
		
		ssl_stapling_verify on;

		# 中間證書所在路徑【中間證書,這個可以自己生成,具體操作可以參考我另外一篇博客https://blog.csdn.net/qq_41865652/article/details/116048879】
		
		ssl_trusted_certificate /path/to/fullchain.pem;
		
		# ssl協議版本
		
		ssl_protocols TLSv1 TLSv1.1 TLSv1.2;

		# ssl協議超時時間	
			
		ssl_session_timeout 1h;

		# sslsession快取大小
			
		ssl_session_cache shared:SSL:50m;

		# ssl安全創術請求請求頭過期時間
		
		add_header Strict-Transport-Security max-age=15768000;
	}
	
	# http永久重定向到https配置如下
	
	server 
	{
		listen 80;
		
		server_name yourdomain.com;
		
		return 301 https://$host$request_uri;
	}

3.10 URL重寫
rewrite    <regex>    <replacement>    [flag];
關鍵字      正則運算式        替代內容         flag標記
  • 關鍵字:其中關鍵字error_log不能改變
  • 正則:perl兼容正則運算式陳述句進行規則匹配
  • 替代內容:將正則匹配的內容替換成replacement
  • flag標記:rewrite支持的flag標記

rewrite引數的標簽段位置【rewrite可以定義在server中、location中、if判斷中】

  • server
  • location
  • if

flag標記說明:

  • last #本條規則匹配完成后,繼續向下匹配新的location URI規則
  • break #本條規則匹配完成即終止,不再匹配后面的任何規則
  • redirect #回傳302臨時重定向,瀏覽器地址會顯示跳轉后的URL地址
  • permanent #回傳301永久重定向,瀏覽器地址欄會顯示跳轉后的URL地址

# 當請求/shop/details?shopId=1時,將請求重寫成/shop/details/1.html

rewrite ^/shop/details/1.html$ /shop/details?shopId=1 last;

# 當請求/shop/details?shopId=*時,將請求重寫成/shop/details/*.html

rewrite ^/shop/details/(.+).html$ /shop/details?shopId=$1 last;

4 nginx組態檔中的location項

增加每一個location

        location /css {
        
        	# root用來設定根目錄,而alias在接受請求的時候在路徑上不會加上location
        	
        	# 使用root的寫法
        	
            root /usr/local/nginx/static;
          
          	# 使用alias的寫法 
          	 
            # alias /usr/local/nginx/static/css;
        }
        
      location /images {
         
            root   /usr/local/nginx/static;

          	# 使用alias的寫法 
          	 
            # alias /usr/local/nginx/static/images;
        }

      location /js {
         
            root   /usr/local/nginx/static;
            
            # 使用alias的寫法 
          	 
            # alias /usr/local/nginx/static/js;
        }

使用一個location

使用正則

location 前綴


沒有前綴 匹配以指定模式開頭的location


= 精準匹配,不是以指定模式開頭


~ 正則匹配,區分大小寫


~* 正則匹配,不區分大小寫


^~ 非正則匹配,匹配以指定模式開頭的location


location匹配順序

  • 多個正則location直接按書寫順序匹配,成功后就不會繼續往后面匹配

  • 普通(非正則)location會一直往下,直到找到匹配度最高的(最大前綴匹配)

  • 當普通location與正則location同時存在,如果正則匹配成功,則不會再執行普通匹配

  • 所有型別location存在時,“=”匹配 > “^~”匹配 > 正則匹配 > 普通(最大前綴匹配)

     location ~*/(css|images|js) {
       
          root   /usr/local/nginx/static;
          
          index  index.html index.htm;
      }
    

轉載請註明出處,本文鏈接:https://www.uj5u.com/ruanti/325539.html

標籤:其他

上一篇:計算機網路第2章(物理層)

下一篇:Linux ? Nginx反向代理配置引數詳解

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • 面試突擊第一季,第二季,第三季

    第一季必考 https://www.bilibili.com/video/BV1FE411y79Y?from=search&seid=15921726601957489746 第二季分布式 https://www.bilibili.com/video/BV13f4y127ee/?spm_id_fro ......

    uj5u.com 2020-09-10 05:35:24 more
  • 第三單元作業總結

    1.前言 這應該是本學期最后一次寫作業總結了吧。總體來說,對作業的節奏也差不多掌握了,作業做起來的效率也更高了。雖然和之前的作業一樣,作業中都要用到新的知識,但是相比之前,更加懂得了如何利用工具以及資料。雖然之間卡過殼,但總體而言,這幾次作業還算完成的比較好。 2.作業程序總結 相比前兩個單元,此單 ......

    uj5u.com 2020-09-10 05:35:41 more
  • 北航OO(2020)第四單元博客作業暨課程總結博客

    北航OO(2020)第四單元博客作業暨課程總結博客 本單元作業的架構設計 在本單元中,由于UML圖具有比較清晰的樹形結構,因此我對其中需要進行查詢操作的元素進行了包裝,在樹的父節點中存盤所有孩子的參考。考慮到性能問題,我采用了快取機制,一次查詢后盡可能快取已經遍歷過的資訊,以減少遍歷次數。 本單元我 ......

    uj5u.com 2020-09-10 05:35:48 more
  • BUAA_OO_第四單元

    一、UML決議器設計 ? 先看下題目:第四單元實作一個基于JDK 8帶有效性檢查的UML(Unified Modeling Language)類圖,順序圖,狀態圖分析器 MyUmlInteraction,實際上我們要建立一個有向圖模型,UML中的物件(元素)可能與同級元素連接,也可與低級元素相連形成 ......

    uj5u.com 2020-09-10 05:35:54 more
  • 6.1邏輯運算子

    邏輯運算子 1. && 短路與 運算式1 && 運算式2 01.運算式1為true并且運算式2也為true 整體回傳為true 02.運算式1為false,將不會執行運算式2 整體回傳為false 03.只要有一個運算式為false 整體回傳為false 2. || 短路或 運算式1 || 運算式2 ......

    uj5u.com 2020-09-10 05:35:56 more
  • BUAAOO 第四單元 & 課程總結

    1. 第四單元:StarUml檔案決議 本單元采用了圖模型決議UML。 UML檔案可以抽象為圖、子圖、邊的邏輯結構。 在實作中,圖的節點包括類、介面、屬性,子圖包括狀態圖、順序圖等。 采用了三次遍歷UML元素的方法建圖,第一遍遍歷建點,第二、三次遍歷設定屬性、連邊,實作圖物件的初始化。這里借鑒了一些 ......

    uj5u.com 2020-09-10 05:36:06 more
  • 談談我對C# 多型的理解

    面向物件三要素:封裝、繼承、多型。 封裝和繼承,這兩個比較好理解,但要理解多型的話,可就稍微有點難度了。今天,我們就來講講多型的理解。 我們應該經常會看到面試題目:請談談對多型的理解。 其實呢,多型非常簡單,就一句話:呼叫同一種方法產生了不同的結果。 具體實作方式有三種。 一、多載 多載很簡單。 p ......

    uj5u.com 2020-09-10 05:36:09 more
  • Python 資料驅動工具:DDT

    背景 python 的unittest 沒有自帶資料驅動功能。 所以如果使用unittest,同時又想使用資料驅動,那么就可以使用DDT來完成。 DDT是 “Data-Driven Tests”的縮寫。 資料:http://ddt.readthedocs.io/en/latest/ 使用方法 dd. ......

    uj5u.com 2020-09-10 05:36:13 more
  • Python里面的xlrd模塊詳解

    那我就一下面積個問題對xlrd模塊進行學習一下: 1.什么是xlrd模塊? 2.為什么使用xlrd模塊? 3.怎樣使用xlrd模塊? 1.什么是xlrd模塊? ?python操作excel主要用到xlrd和xlwt這兩個庫,即xlrd是讀excel,xlwt是寫excel的庫。 今天就先來說一下xl ......

    uj5u.com 2020-09-10 05:36:28 more
  • 當我們創建HashMap時,底層到底做了什么?

    jdk1.7中的底層實作程序(底層基于陣列+鏈表) 在我們new HashMap()時,底層創建了默認長度為16的一維陣列Entry[ ] table。當我們呼叫map.put(key1,value1)方法向HashMap里添加資料的時候: 首先,呼叫key1所在類的hashCode()計算key1 ......

    uj5u.com 2020-09-10 05:36:38 more
最新发布
  • 【中介者設計模式詳解】C/Java/JS/Go/Python/TS不同語言實作

    * 中介者模式是一種行為型設計模式,它可以用來減少類之間的直接依賴關系,
    * 將物件之間的通信封裝到一個中介者物件中,從而使得各個物件之間的關系更加松散。
    * 在中介者模式中,物件之間不再直接相互互動,而是通過中介者來中轉訊息。 ......

    uj5u.com 2023-04-20 08:20:47 more
  • 露天煤礦現場調研和交流案例分享

    他們集團的資訊化公司及研究院在一個礦區正在做智能礦山的統一平臺的 試點,專案投資大概1億,包括了礦山的各方面的內容,顯示得我們這次交流有點多余。他們2年前開始做智能礦山的規劃,有很多煤礦行業專家的加持,他們的描述是非常完美,但是去年底應該上線的平臺,現在還沒有看到影子。他們確實有很多場景需求,但是被... ......

    uj5u.com 2023-04-20 08:20:25 more
  • 《社區人員管理》實戰案例設計&個人案例分享

    設計是一個讓人夢想成真程序,開始編碼、測驗、除錯之前進行需求分析和架構設計,才能保證關鍵方面都做正確 ......

    uj5u.com 2023-04-20 08:20:17 more
  • 軟體架構生態化-多角色交付的探索實踐

    作為一個技術架構師,不僅僅要緊跟行業技術趨勢,還要結合研發團隊現狀及痛點,探索新的交付方案。在日常中,你是否遇到如下問題 “ 業務需求排期長研發是瓶頸;非研發角色感受不到研發技改提效的變化;引入ISV 團隊又擔心質量和安全,培訓周期長“等等,基于此我們探索了一種新的技術體系及交付方案來解決如上問題。 ......

    uj5u.com 2023-04-20 08:20:10 more
  • 【中介者設計模式詳解】C/Java/JS/Go/Python/TS不同語言實作

    * 中介者模式是一種行為型設計模式,它可以用來減少類之間的直接依賴關系,
    * 將物件之間的通信封裝到一個中介者物件中,從而使得各個物件之間的關系更加松散。
    * 在中介者模式中,物件之間不再直接相互互動,而是通過中介者來中轉訊息。 ......

    uj5u.com 2023-04-20 08:19:44 more
  • 露天煤礦現場調研和交流案例分享

    他們集團的資訊化公司及研究院在一個礦區正在做智能礦山的統一平臺的 試點,專案投資大概1億,包括了礦山的各方面的內容,顯示得我們這次交流有點多余。他們2年前開始做智能礦山的規劃,有很多煤礦行業專家的加持,他們的描述是非常完美,但是去年底應該上線的平臺,現在還沒有看到影子。他們確實有很多場景需求,但是被... ......

    uj5u.com 2023-04-20 08:19:07 more
  • 《社區人員管理》實戰案例設計&個人案例分享

    設計是一個讓人夢想成真程序,開始編碼、測驗、除錯之前進行需求分析和架構設計,才能保證關鍵方面都做正確 ......

    uj5u.com 2023-04-20 08:18:57 more
  • 軟體架構生態化-多角色交付的探索實踐

    作為一個技術架構師,不僅僅要緊跟行業技術趨勢,還要結合研發團隊現狀及痛點,探索新的交付方案。在日常中,你是否遇到如下問題 “ 業務需求排期長研發是瓶頸;非研發角色感受不到研發技改提效的變化;引入ISV 團隊又擔心質量和安全,培訓周期長“等等,基于此我們探索了一種新的技術體系及交付方案來解決如上問題。 ......

    uj5u.com 2023-04-20 08:18:49 more
  • 05單件模式

    #經典的單件模式 public class Singleton { private static Singleton uniqueInstance; //一個靜態變數持有Singleton類的唯一實體。 // 其他有用的實體變數寫在這里 //構造器宣告為私有,只有Singleton可以實體化這個類! ......

    uj5u.com 2023-04-19 08:42:51 more
  • 【架構與設計】常見微服務分層架構的區別和落地實踐

    軟體工程的方方面面都遵循一個最基本的道理:沒有銀彈,架構分層模型更是如此,每一種都有各自優缺點,所以請根據不同的業務場景,并遵循簡單、可演進這兩個重要的架構原則選擇合適的架構分層模型即可。 ......

    uj5u.com 2023-04-19 08:42:41 more