詳解nginx前端根據(jù)$remote_addr分發(fā)方法
需求如下:
域名下面有多臺服務器,現(xiàn)針對某個地區(qū)做測試,讓某個地區(qū)的ip用戶只訪問某一臺服務器,單獨做測試,如果沒問題,全部更新;有問題則影響較小,及時發(fā)現(xiàn)問題解決問題;
解決方案:
使用nginx的模塊,在前端負載均衡轉(zhuǎn)發(fā)的機器上,配置匹配規(guī)則;
nginx配置vhost里面,域名下面location段,增加一段代碼
如果$remote_addr 匹配到ip的話,轉(zhuǎn)發(fā)到abc_test_server;
server { listen 80; server_name abc.com.cn; access_log /dev/null; error_log /data/logs/error.log; location / { proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; if ($remote_addr ~ "202.96.134.100") { proxy_pass http://abc_test_server; break; } proxy_pass http://abc_server; } }
負載均衡配置也需要增加一段
#abc_test only upstream abc_test_server { server 192.168.20.10:80; } #abc.com.cn upstream abc_server { server 192.168.20.11:80; server 192.168.20.12:80; server 192.168.20.13:80; }
設定的ip會直接分發(fā)到192.168.20.10這一臺后端服務器中,進行測試;
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
nginx-rtmp-module模塊實現(xiàn)視頻點播的示例代碼
本文主要介紹了nginx-rtmp-module模塊實現(xiàn)視頻點播,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2025-02-02Nginx解決Http慢攻擊(Slow HTTP Attack)的方法
緩慢的HTTP拒絕服務攻擊是一種專門針對于Web的應用層拒絕服務攻擊,本文給大家介紹了Nginx解決Http慢攻擊(Slow HTTP Attack)的方法,需要的朋友可以參考下2024-02-02