本文介紹了通過Nginx反向代理實(shí)現(xiàn)IP訪問分流的示例代碼,分享給大家。具體如下:
通過Nginx做反向代理來實(shí)現(xiàn)分流,以減輕服務(wù)器的負(fù)載和壓力是比較常見的一種服務(wù)器部署架構(gòu)。本文將分享一個(gè)如何根據(jù)來路IP來進(jìn)行分流的方法。
根據(jù)特定IP來實(shí)現(xiàn)分流
將IP地址的最后一段最后一位為0或2或6的轉(zhuǎn)發(fā)至test-01.com來執(zhí)行,否則轉(zhuǎn)發(fā)至test-02.com來執(zhí)行。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
|
upstream test-01.com { server 192.168.1.100:8080; } upstream test-02.com { server 192.168.1.200:8080; } server { listen 80; server_name www.test.com; location / { if ( $remote_addr ~* ^(.*)\.(.*)\.(.*)\.*[026]$){ proxy_pass http://test-01.com; break; } proxy_pass http://test-02.com; } } |
將IP地址前3段為192.168.202.*轉(zhuǎn)發(fā)至test-01.com來執(zhí)行,否則轉(zhuǎn)發(fā)至test-02.com來執(zhí)行。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
|
upstream test-01.com { server 192.168.1.100:8080; } upstream test-02.com { server 192.168.1.200:8080; } server { listen 80; server_name www.test.com; location / { if ( $remote_addr ~* ^(192)\.(168)\.(202)\.(.*)$) { proxy_pass http://test-01.com; break; } proxy_pass http://test-02.com; } } |
根據(jù)指定范圍IP來實(shí)現(xiàn)分流
將IP地址的最后一段為1-100的轉(zhuǎn)發(fā)至test-01.com來執(zhí)行,否則轉(zhuǎn)發(fā)至test-02.com執(zhí)行。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
|
upstream test-01.com { server 192.168.1.100:8080; } upstream test-02.com { server 192.168.1.200:8080; } server { listen 80; server_name www.test.com; location / { if ( $remote_addr ~* ^(.*)\.(.*)\.(.*)\.[1,100]$){ proxy_pass http://test-01.com; break; } proxy_pass http://test-02.com; } } |
根據(jù)forwarded地址分流
將IP地址的第1段為212開頭的訪問轉(zhuǎn)發(fā)至test-01.com來執(zhí)行,否則轉(zhuǎn)發(fā)至test-02.com執(zhí)行。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
|
upstream test-01.com { server 192.168.1.100:8080; } upstream test-02.com { server 192.168.1.200:8080; } server { listen 80; server_name www.test.com; location / { if ( $http_x_forwarded_for ~* ^(212)\.(.*)\.(.*)\.(.*)$){ proxy_pass http://test-01.com; break; } proxy_pass http://test-02.com; } } |
if指令的作用
if指令: 判斷表達(dá)式的值是否為真(true), 如果為真則執(zhí)行后面大括號中的內(nèi)容。
以下是一些條件表達(dá)式的常用比較方法:
- 變量的完整比較可以使用=或!=操作符
- 部分匹配可以使用~或~*的正則表達(dá)式來表示
- ~表示區(qū)分大小寫
- ~*表示不區(qū)分大小寫(nginx與Nginx是一樣的)
- !~與!~*是取反操作,也就是不匹配的意思
- 檢查文件是否存在使用-f或!-f操作符
- 檢查目錄是否存在使用-d或!-d操作符
- 檢查文件、目錄或符號連接是否存在使用-e或!-e操作符
- 檢查文件是否可執(zhí)行使用-x或!-x操作符
- 正則表達(dá)式的部分匹配可以使用括號,匹配的部分在后面可以用$1~$9變量代替
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持服務(wù)器之家。
原文鏈接:http://m.ythuaji.com.cn/Linux/2017-11/148392.htm