Nginx如何配置根據(jù)路徑轉(zhuǎn)發(fā)詳解
先談理解:
1.反向代理:是nginx代理所有的服務(wù)器。而正向代理是vpn代理客戶(hù)端??!
反向代理是配置 proxy_pass 可以只配置一個(gè)地址如 :
proxy_pass http://127.0.0.1:8081;
也可以配置多個(gè)
2.那就是負(fù)載均衡
定義負(fù)載均衡服務(wù)器:
upstream myserver {
server 192.168.12.127:8080;
server 192.168.12.127:8081;
}
修改proxy_pass
proxy_pass http://myserver;
這樣就實(shí)現(xiàn)了 反向代理 (proxy_pass)+ 負(fù)載均衡(upstream)
1.nginx基本概念
Nginx的概念
- 正向代理和反向代理:
- 正向代理:正向代理就是在客戶(hù)端配置代理服務(wù)器,通過(guò)代理服務(wù)器去進(jìn)行互聯(lián)網(wǎng)操作。(VPN代理客戶(hù)端)
- 反向代理:客戶(hù)端發(fā)送請(qǐng)求到反向代理服務(wù)器,由反向代理服務(wù)器去選擇目標(biāo)服務(wù)器獲取它的數(shù)據(jù),在返回給客戶(hù)端。此時(shí)反向代理服務(wù)器和目標(biāo)服務(wù)器對(duì)外就是一臺(tái)服務(wù)器,暴露的是代理服務(wù)器地址,隱藏了真實(shí)的服務(wù)器地址。(代理服務(wù)端)
- 負(fù)載均衡
- 在多個(gè)服務(wù)器的情況下,我們將請(qǐng)求發(fā)放到各個(gè)服務(wù)器上,將原先請(qǐng)求集中到單個(gè)服務(wù)器的情況改為將請(qǐng)求發(fā)送到多個(gè)服務(wù)器上,將負(fù)載分發(fā)到不同的服務(wù)器,也就是負(fù)載均衡
- 動(dòng)靜分離
- 簡(jiǎn)單理解就是把靜態(tài)資源和動(dòng)態(tài)資源分開(kāi)部署。為了加快網(wǎng)站解析的速度,可以把靜態(tài)資源和動(dòng)態(tài)資源部署到不同的服務(wù)器來(lái)解析,加快解析速度。降低單個(gè)服務(wù)器的壓力!
2.常用命令以及配置文件
Win下nginx的常用命令
- 前提:需要進(jìn)入到nginx目錄下在進(jìn)行操作
- nginx -v:查看nginx版本號(hào)
- nginx -s stop:關(guān)閉nginx
- start nginx:?jiǎn)?dòng)nginx
- nginx -s reload:重新加載nginx
- nginx -t 檢查默認(rèn)配置conf
- taskkill /f /im nginx.exe win殺掉nginx
nginx配置文件
- 全局塊
- 主要設(shè)置一些影響n(yōu)ginx服務(wù)器運(yùn)行的配置指令。主要包括配置運(yùn)行nginx服務(wù)器的用戶(hù),允許生成的worker process數(shù),進(jìn)程PID存放路徑,日志存放路徑和類(lèi)型以及配置文件的引入等
- 比如:worker_process 1; 這個(gè)就代表nginx服務(wù)器并發(fā)處理服務(wù)的關(guān)鍵配置,它的值越大,表示支持的并發(fā)處理量越多,但是會(huì)受到硬件,軟件等設(shè)備的約束。
- events塊
- events塊主要影響n(yōu)ginx服務(wù)器與用戶(hù)的網(wǎng)絡(luò)連接,是否開(kāi)啟同時(shí)多個(gè)網(wǎng)絡(luò)連接
- 比如:worker_connections:1024;表示最大連接數(shù)為1024個(gè)
- http塊(http塊包含了http全局塊和server塊)
- 這時(shí)nginx配置最頻繁的部分,代理,緩存,日志等都是在這里配置。
- http全局塊:主要是配置日志等等的配置
- server塊:
- server全局快:listen:參數(shù)對(duì)應(yīng)的是端口號(hào);server_name:地址參數(shù)
- location塊:用來(lái)配置響應(yīng)反向代理的。增加參數(shù)proxy_pass 服務(wù)器(反向代理去到的服務(wù)器)地址(比如:127.0.0.1:8080)
3.nginx配置實(shí)例之反向代理
1. 實(shí)現(xiàn)效果:監(jiān)聽(tīng)9000端口。根據(jù)不同的路徑跳轉(zhuǎn)到不同的端口服務(wù)中
2. 準(zhǔn)備工作
準(zhǔn)備好兩個(gè)服務(wù)器:8080和8081
在8080tomcat的webapps里面添加一個(gè)shisan01文件夾,編寫(xiě)一個(gè)shisan.html。內(nèi)容自己定就好,同理8081也是一樣,添加一個(gè)shisan02文件夾,編寫(xiě)一個(gè)shisan.html。跑完之后訪(fǎng)問(wèn)不同的服務(wù)測(cè)試
3. 前往nginx配置文件配置
進(jìn)入配置文件,如下配置
server {
listen 9000;
server_name 192.168.12.127;
location ~/shisan01/ {
proxy_pass http://127.0.0.1:8080;
}
location ~/shisan02/ {
proxy_pass http://127.0.0.1:8081;
}
}
PS:注意要記得開(kāi)發(fā)端口號(hào):8080 8081 9000
PS:location的指令可以百度了解一下
4.nginx配置實(shí)例之負(fù)載均衡
1. 準(zhǔn)備工作
同樣是兩個(gè)tomcat(8080和8081)服務(wù)器,當(dāng)然要是你真有兩臺(tái)服務(wù)器最好!哈哈哈。條件問(wèn)題還是模擬。
在兩個(gè)服務(wù)器里面的webapps里面創(chuàng)建一個(gè)shisan文件夾,在shisan文件夾里創(chuàng)建一個(gè)shisan.html,添加內(nèi)容自己定就好
2. 在nginx配置文件中修改配置
在http塊中配置
upstream myserver {
server 192.168.12.127:8080;
server 192.168.12.127:8081;
}
server {
listen 80;
server_name 192.168.12.127;
location / {
proxy_pass http://myserver;
root html;
index index.html index.htm;
}
}
3. nginx分配服務(wù)器的策略
輪詢(xún):默認(rèn)策略;每個(gè)請(qǐng)求按時(shí)間順序逐一分配到不同的后端服務(wù)器,如果后端服務(wù)器down掉,能自動(dòng)剔除
權(quán)重:指定輪詢(xún)幾率,weight和訪(fǎng)問(wèn)比率成正比,用于后端服務(wù)器性能不均的情況。
upstream myserver {
server 192.168.12.127:8080 weight=10;
server 192.168.12.127:8081 weight=5;
}
IP綁定 ip_hash:每個(gè)請(qǐng)求按訪(fǎng)問(wèn)ip的hash結(jié)果分配,這樣每個(gè)訪(fǎng)客固定訪(fǎng)問(wèn)一個(gè)后端服務(wù)器,可以解決session的問(wèn)題
upstream myserver {
ip_hash;
server 192.168.12.127:8080;
server 192.168.12.127:8081;
}
fair:按后端服務(wù)器的響應(yīng)時(shí)間來(lái)分配請(qǐng)求,響應(yīng)時(shí)間短的優(yōu)先分配。
upstream backserver {
server 192.168.12.127:8080;
server 192.168.12.127:8081;
fair;
}
url_hash:按訪(fǎng)問(wèn)url的hash結(jié)果來(lái)分配請(qǐng)求,使每個(gè)url定向到同一個(gè)后端服務(wù)器,后端服務(wù)器為緩存時(shí)比較有效。
5.nginx配置實(shí)例之動(dòng)靜分離
1. 準(zhǔn)備工作
弄好一個(gè)動(dòng)態(tài)資源一個(gè)靜態(tài)資源:比如
- /shisan/image/01.jpg
- /shisan/html/01.html
2. 配置nginx文件
server {
listen 80;
server_name 192.168.12.127;
location /html/ {
root /shisan/;
index index.html index.htm;
}
location /image/ {
root /shisan/;
autoindex on; // 列出文件的目錄,可以自行觀看對(duì)比就知道
}
}
6.nginx配置高可用集群
1. 因?yàn)槲疫@里環(huán)境不允許,可以參考這個(gè)文章
Location規(guī)則
語(yǔ)法規(guī)則: location [=||*|^~] /uri/ {… }
首先匹配 =,其次匹配^~,其次是按文件中順序的正則匹配,最后是交給 /通用匹配。當(dāng)有匹配成功時(shí)候,停止匹配,按當(dāng)前匹配規(guī)則處理請(qǐng)求。
| 符號(hào) | 含義 |
|---|---|
| = | = 開(kāi)頭表示精確匹配 |
| ^~ | ^~開(kāi)頭表示uri以某個(gè)常規(guī)字符串開(kāi)頭,理解為匹配 url路徑即可。nginx不對(duì)url做編碼,因此請(qǐng)求為/static/20%/aa,可以被規(guī)則^~ /static/ /aa匹配到(注意是空格) |
| ~ | ~ 開(kāi)頭表示區(qū)分大小寫(xiě)的正則匹配 |
| ~* | ~ 開(kāi)頭表示不區(qū)分大小寫(xiě)的正則匹配* |
| !和!* | !和!*分別為區(qū)分大小寫(xiě)不匹配及不區(qū)分大小寫(xiě)不匹配的正則 |
| / | 用戶(hù)所使用的代理(一般為瀏覽器) |
| $http_x_forwarded_for | 可以記錄客戶(hù)端IP,通過(guò)代理服務(wù)器來(lái)記錄客戶(hù)端的ip地址 |
| $http_referer | 可以記錄用戶(hù)是從哪個(gè)鏈接訪(fǎng)問(wèn)過(guò)來(lái)的 |
比這些 location 規(guī)則來(lái)選擇一個(gè) location,對(duì)比的順序可以總結(jié)為:
- 首先匹配前綴匹配(沒(méi)有 RE 表達(dá)式),針對(duì)當(dāng)前這個(gè)請(qǐng)求,每個(gè)前綴匹配都匹配一遍.
- 搜索=匹配,如果當(dāng)前請(qǐng)求匹配上了,搜索將會(huì)停止,直接使用這個(gè)這個(gè) location.
- 如果第二步?jīng)]有匹配上,nginx 會(huì)按照如下步驟繼續(xù)搜索最長(zhǎng)前綴匹配:
3.1 如果最長(zhǎng)前綴匹配有^~這個(gè)modifier,nginx 會(huì)停止搜索并直接使用這個(gè) location.
3.2 如果沒(méi)有使用 ^~,暫存這個(gè) location并且繼續(xù)搜索. - 只要最長(zhǎng)前綴匹配被暫存和選中,nginx 就會(huì)看當(dāng)前的 location 是否有大小寫(xiě)敏感的 RE(~和~*),第一個(gè)匹配上這種會(huì)被當(dāng)做有效的 location來(lái)處理這個(gè)請(qǐng)求.
- 如果沒(méi)有 RE 的 location 匹配上,前面暫存的 location 就會(huì)被選中來(lái)處理這個(gè)請(qǐng)求.
舉例
如下是一些 location 配置的例子,用來(lái)詳細(xì)描述上面所說(shuō)的處理順序,你也可以按照具體實(shí)際情況來(lái)修改這些例子.
location = / {
# 只處理請(qǐng)求 /.
}
location /data/ {
# 所有以 /data/ 匹配,但是還會(huì)繼續(xù)搜索.
# 如果沒(méi)有其他 location 匹配上,就用這個(gè)處理請(qǐng)求.
}location ^~ /img/ {
# 所有以 /img/ 開(kāi)頭的請(qǐng)求并且會(huì)停止搜索.
}location ~* .(png|gif|ico|jpg|jpeg)$ {
# 以png, gif, ico, jpg ,jpeg結(jié)尾的請(qǐng)求.
# 如果請(qǐng)求是到 /img/ 路徑的話(huà) 還是會(huì)被上面??的 location 處理
}總結(jié)
到此這篇關(guān)于Nginx如何配置根據(jù)路徑轉(zhuǎn)發(fā)的文章就介紹到這了,更多相關(guān)Nginx根據(jù)路徑轉(zhuǎn)發(fā)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Nginx緩存在服務(wù)端 代理和客戶(hù)端的區(qū)別深入探索
這篇文章主要介紹了Nginx緩存在服務(wù)端 代理和客戶(hù)端的區(qū)別深入探索,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-10-10
nginx使用replace-filter-nginx-module實(shí)現(xiàn)內(nèi)容替換的示例
本篇文章主要介紹了nginx使用replace-filter-nginx-module實(shí)現(xiàn)內(nèi)容替換的示例,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-03-03
Nginx Proxy 代理測(cè)試的實(shí)現(xiàn)
本文主要介紹了Nginx Proxy 代理測(cè)試的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2025-02-02
一文詳解Nginx的訪(fǎng)問(wèn)限制與訪(fǎng)問(wèn)控制
訪(fǎng)問(wèn)限制是一種防止惡意訪(fǎng)問(wèn)的常用手段,可以指定同一IP地址在固定時(shí)間內(nèi)的訪(fǎng)問(wèn)次數(shù),訪(fǎng)問(wèn)控制是控制客戶(hù)端對(duì)服務(wù)端的訪(fǎng)問(wèn),并非僅限制請(qǐng)求次數(shù),而是允許某些請(qǐng)求或者直接拒絕某些請(qǐng)求,本文給大家具體介紹了Nginx的訪(fǎng)問(wèn)限制與訪(fǎng)問(wèn)控制,需要的朋友可以參考下2024-09-09

