目錄
proxy protocol在nginx中應用
在RealIP擴充模組中,$proxy_protocol_addr和$proxy_protocol_port 表示的意義不變,還是原始客戶端的IP位址和連接埠號碼。
上面我們提到了nginx中proxy protocol的基本應用,下面來講一下如何在nginx中進行具體的設定。
透過上面的配置,nginx可以實現在tcp/udp協定和http/https協定同時支援proxy protocol。
然後我們需要將proxy或SLB的IP位址替換為真實客戶端的位址,那麼可以這樣使用:
http和stream的設定方式是不同的。
首頁 運維 Nginx nginx中怎麼設定使用proxy protocol協定

nginx中怎麼設定使用proxy protocol協定

May 18, 2023 am 08:47 AM
nginx proxy protocol

    proxy protocol在nginx中應用

    #我們知道nginx是web伺服器和代理伺服器,它一般工作在proxy server或負載平衡軟體(Haproxy ,Amazon Elastic Load Balancer (ELB)的後面。

    首先,客戶端向代理伺服器或負載平衡軟體發起請求,然後請求會被轉發到nginx進行實際的web存取。

    因為經過了多層軟體,所以客戶端的一些資訊例如ip位址,連接埠號碼等可能就會被隱藏,這對於我們問題分析,資料統計都是不利的。我們希望獲得客戶端真實的IP位址,以便獲取準確的請求環境。

    這種情況下就需要用到PROXY protocol了。

    #如果前面所說的proxy或LSB都實現了PROXY protocol協定的話,不管是HTTP, SSL , HTTP/2, SPDY, WebSocket 還是TCP協議,nginx都可以拿到客戶端的原始IP位址,從而根據原始IP位址進行一些特殊的操作,例如屏蔽惡意IP的訪問,根據IP不同展示不同的語言或頁面,或者更簡單的日誌記錄和統計等,都非常有效。

    當然,如果想要支援PROXY protocol,對nginx的版本也是有要求的,具體版本需求如下:

    • 想要支援PROXY protocol v2,需要NGINX Plus R16或NGINX Open Source 1.13.11。

    • 想要支援ROXY protocol for HTTP,需要NGINX Plus R3或NGINX Open Source 1.5.12。

    • 想要支援TCP client‑side PROXY protocol,需要NGINX Plus R7或NGINX Open Source 1.9.3。

    • ##想要支援PROXY protocol for TCP,需要NGINX Plus R11 或NGINX Open Source 1.11.4。

    在nginx中可以透過下面的變數來取得對應的客戶端資訊,具體而言如下所示:

    $proxy_protocol_addr和$proxy_protocol_port 分別表示的是原始客戶端的IP位址和連接埠號碼。

    $remote_addr 和 $remote_port表示的是load balancer的的IP位址和連接埠。

    如果你使用了RealIP擴充模組,那麼這個模組會重寫$remote_addr 和 $remote_port這兩個值,將其替換成原始客戶端的IP位址和連接埠號碼。

    然後使用$realip_remote_addr 和 $realip_remote_port來表示load balancer的的IP位址和連接埠。

    在RealIP擴充模組中,$proxy_protocol_addr和$proxy_protocol_port 表示的意義不變,還是原始客戶端的IP位址和連接埠號碼。

    在nginx中設定使用proxy protocol

    上面我們提到了nginx中proxy protocol的基本應用,下面來講一下如何在nginx中進行具體的設定。

    在nginx中啟用proxy protocol

    如果你的nginx已經是支援proxy protocol的版本,那麼啟用proxy protocol非常簡單,只需要在server中的listen中加入proxy_protocol即可,如下:

    http {
        #...
        server {
            listen 80   proxy_protocol;
            listen 443  ssl proxy_protocol;
            #...
        }
    }
       
    stream {
        #...
        server {
            listen 112233 proxy_protocol;
            #...
        }
    }
    登入後複製

    大家比較熟悉的是http block,在nginx中,它表示對http/https的支持。 Nginx提供了對TCP/UDP協定的支持,這項功能透過stream模組實現,對許多人來說比較陌生。

    透過上面的配置,nginx可以實現在tcp/udp協定和http/https協定同時支援proxy protocol。

    使用Real‑IP modules

    Real‑IP modules是nginx自帶的一個模組,可以透過下面的指令來查看nginx是否有安裝real-ip模組:

    nginx -V 2>&1 | grep -- 'http_realip_module'
    nginx -V 2>&1 | grep -- 'stream_realip_module'
    登入後複製

    如果你目前使用的版本沒有real ip,也不要急,這時候你可能需要從原始碼編譯。

    在編譯的過程中,我們需要執行一個configure指令,在這個configure指令中可以指定要開啟的功能,例如stream或http_ssl_module:

    $ ./configure
    --sbin-path=/usr/local/nginx/nginx
    --conf-path=/usr/local/nginx/nginx.conf
    --pid-path=/usr/local/nginx/nginx.pid
    --with-pcre=../pcre-8.44
    --with-zlib=../zlib-1.2.11
    --with-http_ssl_module
    --with-stream
    --with-mail
    登入後複製

    如果要開啟real-ip功能,則可以新增:

    --with-http_realip_module
    登入後複製

    如果nginx是運行在SLB或proxy之後的,那麼可以透過set_real_ip_from指令來指定代理程式或負載平衡伺服器的IP範圍,如下所示:

    server {
        #...
        set_real_ip_from 192.168.1.0/24;
       #...
    }
    登入後複製

    然後我們需要將proxy或SLB的IP位址替換為真實客戶端的位址,那麼可以這樣使用:

    http {
        server {
            #...
            real_ip_header proxy_protocol;
          }
    }
    登入後複製

    請求轉送

    不管是http還是stream block,都可能會遇到請求向後續的upstream進行轉送的情況,對於upstream來說,他們希望收到的是真實客戶端IP位址,而不是proxy或slb的位址,那麼可以透過下面的設定來解決:

    http {
        proxy_set_header X-Real-IP       $proxy_protocol_addr;
        proxy_set_header X-Forwarded-For $proxy_protocol_addr;
    }
    登入後複製
    stream {
        server {
            listen 12345;
            proxy_pass example.com:12345;
            proxy_protocol on;
        }
    }
    登入後複製

    http和stream的設定方式是不同的。

    日誌記錄

    日誌是一個非常重要的功能,對於定位問題,執行資料統計分析都非常有用,當然我們需要的是真實的客戶端IP位址。

    ###我們可以透過使用變數$proxy_protocol_addr在http和stream block中記錄對應的日誌,如下所示:###
    http {
        #...
        log_format combined '$proxy_protocol_addr - $remote_user [$time_local] '
                            '"$request" $status $body_bytes_sent '
                            '"$http_referer" "$http_user_agent"';
    }
    登入後複製
    stream {
        #...
        log_format basic '$proxy_protocol_addr - $remote_user [$time_local] '
                          '$protocol $status $bytes_sent $bytes_received '
                          '$session_time';
    }
    登入後複製

    以上是nginx中怎麼設定使用proxy protocol協定的詳細內容。更多資訊請關注PHP中文網其他相關文章!

    本網站聲明
    本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

    熱AI工具

    Undresser.AI Undress

    Undresser.AI Undress

    人工智慧驅動的應用程序,用於創建逼真的裸體照片

    AI Clothes Remover

    AI Clothes Remover

    用於從照片中去除衣服的線上人工智慧工具。

    Undress AI Tool

    Undress AI Tool

    免費脫衣圖片

    Clothoff.io

    Clothoff.io

    AI脫衣器

    Video Face Swap

    Video Face Swap

    使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

    熱門文章

    <🎜>:泡泡膠模擬器無窮大 - 如何獲取和使用皇家鑰匙
    3 週前 By 尊渡假赌尊渡假赌尊渡假赌
    北端:融合系統,解釋
    3 週前 By 尊渡假赌尊渡假赌尊渡假赌
    Mandragora:巫婆樹的耳語 - 如何解鎖抓鉤
    3 週前 By 尊渡假赌尊渡假赌尊渡假赌

    熱工具

    記事本++7.3.1

    記事本++7.3.1

    好用且免費的程式碼編輯器

    SublimeText3漢化版

    SublimeText3漢化版

    中文版,非常好用

    禪工作室 13.0.1

    禪工作室 13.0.1

    強大的PHP整合開發環境

    Dreamweaver CS6

    Dreamweaver CS6

    視覺化網頁開發工具

    SublimeText3 Mac版

    SublimeText3 Mac版

    神級程式碼編輯軟體(SublimeText3)

    熱門話題

    Java教學
    1665
    14
    CakePHP 教程
    1424
    52
    Laravel 教程
    1322
    25
    PHP教程
    1270
    29
    C# 教程
    1250
    24
    nginx在windows中怎麼配置 nginx在windows中怎麼配置 Apr 14, 2025 pm 12:57 PM

    如何在 Windows 中配置 Nginx?安裝 Nginx 並創建虛擬主機配置。修改主配置文件並包含虛擬主機配置。啟動或重新加載 Nginx。測試配置並查看網站。選擇性啟用 SSL 並配置 SSL 證書。選擇性設置防火牆允許 80 和 443 端口流量。

    docker怎麼啟動容器 docker怎麼啟動容器 Apr 15, 2025 pm 12:27 PM

    Docker 容器啟動步驟:拉取容器鏡像:運行 "docker pull [鏡像名稱]"。創建容器:使用 "docker create [選項] [鏡像名稱] [命令和參數]"。啟動容器:執行 "docker start [容器名稱或 ID]"。檢查容器狀態:通過 "docker ps" 驗證容器是否正在運行。

    docker容器名稱怎麼查 docker容器名稱怎麼查 Apr 15, 2025 pm 12:21 PM

    可以通過以下步驟查詢 Docker 容器名稱:列出所有容器(docker ps)。篩選容器列表(使用 grep 命令)。獲取容器名稱(位於 "NAMES" 列中)。

    怎麼查看nginx是否啟動 怎麼查看nginx是否啟動 Apr 14, 2025 pm 01:03 PM

    確認 Nginx 是否啟動的方法:1. 使用命令行:systemctl status nginx(Linux/Unix)、netstat -ano | findstr 80(Windows);2. 檢查端口 80 是否開放;3. 查看系統日誌中 Nginx 啟動消息;4. 使用第三方工具,如 Nagios、Zabbix、Icinga。

    docker怎麼創建容器 docker怎麼創建容器 Apr 15, 2025 pm 12:18 PM

    在 Docker 中創建容器: 1. 拉取鏡像: docker pull [鏡像名] 2. 創建容器: docker run [選項] [鏡像名] [命令] 3. 啟動容器: docker start [容器名]

    nginx怎麼配置雲服務器域名 nginx怎麼配置雲服務器域名 Apr 14, 2025 pm 12:18 PM

    在雲服務器上配置 Nginx 域名的方法:創建 A 記錄,指向雲服務器的公共 IP 地址。在 Nginx 配置文件中添加虛擬主機塊,指定偵聽端口、域名和網站根目錄。重啟 Nginx 以應用更改。訪問域名測試配置。其他注意事項:安裝 SSL 證書啟用 HTTPS、確保防火牆允許 80 端口流量、等待 DNS 解析生效。

    nginx怎麼查版本 nginx怎麼查版本 Apr 14, 2025 am 11:57 AM

    可以查詢 Nginx 版本的方法有:使用 nginx -v 命令;查看 nginx.conf 文件中的 version 指令;打開 Nginx 錯誤頁,查看頁面的標題。

    nginx服務器掛了怎麼辦 nginx服務器掛了怎麼辦 Apr 14, 2025 am 11:42 AM

    當 Nginx 服務器宕機時,可執行以下故障排除步驟:檢查 nginx 進程是否正在運行。查看錯誤日誌以獲取錯誤消息。檢查 nginx 配置語法正確性。確保 nginx 具有訪問文件所需的權限。檢查文件描述符打開限制。確認 nginx 正在偵聽正確的端口。添加防火牆規則以允許nginx流量。檢查反向代理設置,包括後端服務器可用性。如需進一步幫助,請聯繫技術支持。

    See all articles