詳解Nginx中的geo模塊與利用其配置負(fù)載均衡的示例
geo指令使用ngx_http_geo_module模塊提供的。默認(rèn)情況下,nginx有加載這個(gè)模塊,除非人為的 --without-http_geo_module。
ngx_http_geo_module模塊可以用來(lái)創(chuàng)建變量,其值依賴于客戶端IP地址。
geo指令
語(yǔ)法: geo [$address] $variable { ... }
默認(rèn)值: —
配置段: http
定義從指定的變量獲取客戶端的IP地址。默認(rèn)情況下,nginx從$remote_addr變量取得客戶端IP地址,但也可以從其他變量獲得。如
geo $remote_addr $geo { default 0; 127.0.0.1 1; } geo $arg_ttlsa_com $geo { default 0; 127.0.0.1 1; }
如果該變量的值不能代表一個(gè)合法的IP地址,那么nginx將使用地址“255.255.255.255”。
nginx通過(guò)CIDR或者地址段來(lái)描述地址,支持下面幾個(gè)參數(shù):
- delete:刪除指定的網(wǎng)絡(luò)
- default:如果客戶端地址不能匹配任意一個(gè)定義的地址,nginx將使用此值。 如果使用CIDR,可以用“0.0.0.0/0”代替default。
- include: 包含一個(gè)定義地址和值的文件,可以包含多個(gè)。
- proxy:定義可信地址。 如果請(qǐng)求來(lái)自可信地址,nginx將使用其“X-Forwarded-For”頭來(lái)獲得地址。 相對(duì)于普通地址,可信地址是順序檢測(cè)的。
- proxy_recursive:開啟遞歸查找地址。 如果關(guān)閉遞歸查找,在客戶端地址與某個(gè)可信地址匹配時(shí),nginx將使用“X-Forwarded-For”中的最后一個(gè)地址來(lái)代替原始客戶端地址。如果開啟遞歸查找,在客戶端地址與某個(gè)可信地址匹配時(shí),nginx將使用“X-Forwarded-For”中最后一個(gè)與所有可信地址都不匹配的地址來(lái)代替原始客戶端地址。
- ranges:使用以地址段的形式定義地址,這個(gè)參數(shù)必須放在首位。為了加速裝載地址庫(kù),地址應(yīng)按升序定義。
geo $country { default ZZ; include conf/geo.conf; delete 127.0.0.0/16; proxy 192.168.100.0/24; proxy 2001:0db8::/32; 127.0.0.0/24 US; 127.0.0.1/32 RU; 10.1.0.0/16 RU; 192.168.1.0/24 UK; }
vim conf/geo.conf
10.2.0.0/16 RU; 192.168.2.0/24 RU;
地址段例子:
geo $country { ranges; default ZZ; 127.0.0.0-127.0.0.0 US; 127.0.0.1-127.0.0.1 RU; 127.0.0.1-127.0.0.255 US; 10.1.0.0-10.1.255.255 RU; 192.168.1.0-192.168.1.255 UK; }
geo指令主要是根據(jù)IP來(lái)對(duì)變量進(jìn)行賦值的。因此geo塊下只能定義IP或網(wǎng)絡(luò)段,否則會(huì)報(bào)錯(cuò)。
geo模塊實(shí)現(xiàn)全局負(fù)載均衡
server1 : 192.168.6.101
server2 : 192.168.6.102
server3 : 192.168.6.121
測(cè)試機(jī)1 IP:192.168.6.2
測(cè)試機(jī)2 IP:192.168.6.8
測(cè)試機(jī)3 IP:192.168.6.189
1.在每臺(tái)server上都編譯安裝 nginx ,我就不多說(shuō)了!
server1,與server2 的配置我沒(méi)有改動(dòng)~只把他的主頁(yè)改一下,這樣有利于測(cè)試!
server1 :
shell $> cd /usr/local/nginx/html shell $> rm index.html shell $> echo "192.168.6.101" > index.html
server2:
shell $> cd /usr/local/nginx/html shell $> rm index.html shell $> echo "192.168.6.102" > index.html
把他們的服務(wù)都起來(lái)
shell $> /usr/local/nginx/sbin/nginx
2.修改 server3 的配置`
shell $> cd /usr/local/nginx/conf/ shell $> vim nginx.conf
worker_processes 1; events { worker_connections 1024; } http { include mime.types; default_type application/octet-stream; geo $geo { default default; 192.168.6.189/32 uk; 192.168.6.8/32 us; #這里的子網(wǎng)碼是 32 是因?yàn)椋沂菃尉W(wǎng)段測(cè)試,如果你有VLAN,你可以是24 例如 # 192.168.0.0/24 tw } upstream uk.server { server 192.168.6.101; } upstream us.server { server 192.168.6.102; } upstream default.server { server 192.168.6.121:8080; } sendfile on; keepalive_timeout 65; server { listen 80; server_name 192.168.6.121; index index.html index.htm; root html; 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://$geo.server$request_uri; } error_page 500 502 503 504 /50x.html; location = /50x.html { root html; } } server { listen 8080; server_name 192.168.6.121; location / { root html; index index.html index.htm; } } }
3.測(cè)試,在測(cè)試機(jī)1 上打開瀏覽器輸入
http://192.168.6.121
顯示
因?yàn)?測(cè)試機(jī)1 IP地址為 192.168.6.2 按照 nginx 配置,他訪問(wèn)的很明顯是 server3 8080 端口!因?yàn)?server1 server2 的 index.html 我修改了
在 測(cè)試機(jī)2 上打開瀏覽器~輸入
http://192.168.6.121
顯示
在 測(cè)試機(jī)3上打開瀏覽器~輸入
http://192.168.6.121
測(cè)試機(jī)3 IP為 192.168.6.189
顯示:
很明顯,負(fù)載均衡起到了作用~~~
這樣就可以把 三臺(tái)服務(wù)器分別放到不同的IDC 機(jī)房。然后在數(shù)據(jù)同步就可以了~這樣做的好處就是省去了在DNS 上做手腳,因?yàn)橹悄蹹NS 有時(shí)候按照來(lái)訪IP解析的時(shí)候會(huì)解析對(duì)方的DNS地址,把他匹配到一臺(tái)服務(wù)器,如果對(duì)方是網(wǎng)通用戶,他用的電信DNS,會(huì)直接把他匹配到電信的服務(wù)器,NGINX,確確實(shí)實(shí)的根據(jù)來(lái)訪問(wèn)IP來(lái)匹配服務(wù)器的,這樣只要我們把各地區(qū)的IP段收集起來(lái)就可以了~~
相關(guān)文章
詳解Nginx 動(dòng)態(tài) DNS 反向代理的幾種寫法
這篇文章主要介紹了詳解Nginx 動(dòng)態(tài) DNS 反向代理的幾種寫法,詳細(xì)的介紹了Nginx 動(dòng)態(tài) DNS 反向代理的4種方法,非常具有實(shí)用價(jià)值,需要的朋友可以參考下2018-05-05nginx 多個(gè)location轉(zhuǎn)發(fā)任意請(qǐng)求或訪問(wèn)靜態(tài)資源文件的實(shí)現(xiàn)
這篇文章主要介紹了nginx 多個(gè)location轉(zhuǎn)發(fā)任意請(qǐng)求或訪問(wèn)靜態(tài)資源文件的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-11-11nginx有哪些常規(guī)調(diào)優(yōu)手段詳解
性能調(diào)優(yōu)就是用更少的資源提供更好的服務(wù),成本利益最大化,下面這篇文章主要給大家介紹了關(guān)于nginx有哪些常規(guī)調(diào)優(yōu)手段的相關(guān)資料,需要的朋友可以參考下2023-01-01使用log_format為Nginx服務(wù)器設(shè)置更詳細(xì)的日志格式方法
下面小編就為大家分享一篇使用log_format為Nginx服務(wù)器設(shè)置更詳細(xì)的日志格式方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-03-03詳解Nginx服務(wù)器的nginx-http-footer-filter模塊配置
這篇文章主要介紹了Nginx服務(wù)器的nginx-http-footer-filter模塊配置,nginx-http-footer-filter用作在請(qǐng)求的頁(yè)面底部插入代碼,需要的朋友可以參考下2016-01-01nginx 負(fù)載均衡 多站點(diǎn)共享Session
這里我們就 演練一下 以數(shù)據(jù)庫(kù)的形來(lái)存儲(chǔ)Session,來(lái)實(shí)現(xiàn)多站點(diǎn)共享Session2012-11-11Nginx中配置用戶服務(wù)器訪問(wèn)認(rèn)證的方法示例
這篇文章主要介紹了Nginx中配置用戶服務(wù)器訪問(wèn)認(rèn)證的方法示例,包括一個(gè)用perl腳本來(lái)實(shí)現(xiàn)的方法,需要的朋友可以參考下2016-01-01nginx訪問(wèn)報(bào)403錯(cuò)誤的幾種情況詳解
最近訪問(wèn)新安裝的nginx,發(fā)現(xiàn)報(bào)403錯(cuò)誤,所以這篇文章主要給大家介紹了關(guān)于nginx訪問(wèn)報(bào)403錯(cuò)誤的幾種情況,文中通過(guò)圖文介紹的非常詳細(xì),需要的朋友可以參考下2022-07-07