在多云環境透析連接ngx_stream_proxy_protocol_vendor_module

1、模塊定位與價值

  • 多云接入:在同一 Nginx 實例前端接入來自多云平臺的私有鏈路時,能區分 AWS、GCP、Azure 特有的連接 ID。
  • 安全審計:自動記錄云平臺側的 Endpoint/VPC ID,有助于聯調和安全事件追蹤。
  • 路由分流:基于不同云平臺的私有鏈路 ID,定制化分發到各自后端或日志系統。

模塊在 Stream 層 讀取 PROXY Protocol v2 的 TLV(Type-Length-Value)字段,將其映射為 $proxy_protocol_tlv_* 變量供業務使用。

2、支持的云平臺與變量

云平臺TLV 字段對應變量含義
AWSAWS VPC Endpoint ID$proxy_protocol_tlv_aws_vpce_id私有鏈路端點 ID(如 vpce-0123456789abcdef0
GCPPSC Connection ID$proxy_protocol_tlv_gcp_conn_idPrivate Service Connect 會話標識
AzurePrivate Endpoint Link ID$proxy_protocol_tlv_azure_pel_id私有終結點鏈接 ID

前置要求

  1. 上游 LB/網關需支持 PROXY Protocol v2,并將對應云平臺 TLV 字段填寫完整。
  2. 在 Nginx listen … proxy_protocol; 開啟后接收協議頭。

3、最簡配置示例

stream {server {listen 9000 proxy_protocol;# 立即返回 GCP PSC 連接 IDreturn 200 '$proxy_protocol_tlv_gcp_conn_id\n';}
}
  • 客戶端(或上游負載均衡器)連入時攜帶 PROXY v2 TLV 中的 gcp_conn_id
  • Nginx 解析后將該 ID 寫入 $proxy_protocol_tlv_gcp_conn_id 并直接響應。

4、高級應用

  1. 審計日志

    stream {log_format audit '$remote_addr -> $proxy_protocol_addr | ''aws_vpce=$proxy_protocol_tlv_aws_vpce_id ''gcp_conn=$proxy_protocol_tlv_gcp_conn_id ''az_pel=$proxy_protocol_tlv_azure_pel_id';access_log /var/log/nginx/stream_audit.log audit;...
    }
    

    集中記錄多云接入鏈路,方便安全團隊關聯云端事件。

  2. 云平臺分流

    stream {map $proxy_protocol_tlv_aws_vpce_id $upstream {default             backend-default:9000;~^vpce-aws-prod-    aws-prod-backend:9000;}server {listen 9000 proxy_protocol;proxy_pass $upstream;}
    }
    

    通過 map 將 AWS PrivateLink 不同 Endpoint 轉發至對應集群。

  3. 動態下游切換
    結合 keyval,將 $proxy_protocol_tlv_azure_pel_id 與后端列表在線關聯,無需 reload 即可拓撲變更。

5、注意事項

  • PROXY Protocol 版本:僅支持 v2(TLV 擴展);v1(純文本)不包含 TLV。
  • TLV 長度限制:云平臺 TLV 值長度各異,Nginx 會原樣返回,不進行截斷。
  • 安全隔離:務必搭配 proxy_protocol 校驗和其他 ACL,避免惡意偽造 TLV。
  • 性能影響:解析僅在握手階段完成,典型開銷 < 200 μs,不影響高并發吞吐。

6、總結

ngx_stream_proxy_protocol_vendor_module 讓 Nginx Stream 層具備「看懂云廠商私有鏈路標識」的能力,為多云場景下的 安全審計、鏈路分流、故障診斷 提供了輕量級、零侵入的解決方案。無需外部腳本或下層網絡設備配合,只要上游輸出標準 PROXY v2 TLV,即可在 Nginx 中輕松引用、記錄或基于其做自定義轉發。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/pingmian/84716.shtml
繁體地址,請注明出處:http://hk.pswp.cn/pingmian/84716.shtml
英文地址,請注明出處:http://en.pswp.cn/pingmian/84716.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

力扣:基本計算器

基本計算器: 224. 基本計算器 - 力扣&#xff08;LeetCode&#xff09; 本體思路為&#xff0c;將中綴表達式轉為后綴表達式&#xff0c;通過后綴表達式進行運算。 中綴表達式: 我們日常生活中熟知的表達式如12-30 就是一個中綴表達式。 后綴表達式: 150. 逆波蘭表達式求值 - …

《AI日報 · 0613|ChatGPT支持導出、Manus免費開放、GCP全球宕機》

AI 資訊 1?? OpenAI ChatGPT Canvas新增多格式導出功能 OpenAI終于為ChatGPT Canvas推出了用戶期待已久的導出功能。現在,用戶可以將創作內容導出為多種格式:文檔類支持PDF、docx和markdown格式,代碼文件則可直接保存為對應擴展名的源文件(如.py、.js、.sql等)。這一功…

C++中的零拷貝技術

一、C中零拷貝技術的核心概念 零拷貝&#xff08;Zero-copy&#xff09;是一種重要的優化技術&#xff0c;旨在減少數據在內存中的不必要復制&#xff0c;從而提高程序性能、降低內存使用并減少CPU消耗。在C中&#xff0c;零拷貝技術通過多種方式實現&#xff0c;包括引用語義…

RT_Thread內核源碼分析(五)——內存管理@小堆內存管理算法

目錄 1、內存堆控制 1.1 內存堆控制器 1.2 內存塊節點 1.3 內存堆管理 2、內存堆初始化 2.1 初始化接口 2.2 初始化示例 2.3 源碼分析 3、內存堆操作 3.1 內存塊申請 3.1.1 相關接口 3.1.2 原理分析 3.1.3 示例分析 3.1.4 代碼分析 3.2 內存塊伸縮 3.2.1 相關…

MyBatis-Plus 混合使用 XML 和注解

mybatisplus代碼生成器&#xff1a; 版本匹配是個比較麻煩的問題&#xff0c;這是我的配置&#xff1a; <dependency><groupId>com.baomidou</groupId><artifactId>mybatis-plus-boot-starter</artifactId><version>3.5.2</version>…

基于ssm的教學質量評估系統

博主介紹&#xff1a;java高級開發&#xff0c;從事互聯網行業六年&#xff0c;熟悉各種主流語言&#xff0c;精通java、python、php、爬蟲、web開發&#xff0c;已經做了六年的畢業設計程序開發&#xff0c;開發過上千套畢業設計程序&#xff0c;沒有什么華麗的語言&#xff0…

【STM32】G030單片機開啟超過8個ADC通道的方法

如圖所示通道數量已經超過8個&#xff0c;按照之前博客的辦法已經行不通了 CubeMX配置STM32F103C8T6多路ADC配合DMA采集_stm32f103c8t6的adc采樣率-CSDN博客 這里筆者開了10個channel&#xff0c;注意切換為不完全配置&#xff0c;否則的話最多只有8個rank 開DMA&#xff0c;…

不同網絡I/O模型的原理

目錄 1、I/O的介紹 1.1、I/O 操作分類 1.2、I/O操作流程階段 1.3、I/O分類 2、同步I/O 2.1、阻塞I/O 2.2、非阻塞I/O 2.3、I/O復用 2.4、信號驅動式I/O 3、異步I/O 前言 在網絡I/O之中&#xff0c;I/O操作往往會涉及到兩個系統對象&#xff0c;一個是用戶空間調用I/O…

在正則表達式中語法 (?P<名字>內容)

&#x1f3af; 重點解釋&#xff1a;?P<xxx> 是什么語法&#xff1f; 這一整段&#xff1a; (?P<xxx>...)是 Python 正則表達式中 “命名捕獲組” 的語法。 咱們現在一個字一個字來解釋&#xff1a; ? (?...) 是干啥的&#xff1f; 這是一個捕獲組&#xff…

中興B860AV1.1_MSO9280_降級后開ADB-免刷機破解教程(非刷機)

中興B860AV1.1江蘇移動-自動降級包 關于中興b860av1.1頑固盒子降級教程終極版 將附件解壓好以后&#xff0c;準備一個8G以下的U盤重新格式化為FAT32格式后&#xff0c;并插入電腦 將以下文件及文件夾一同復制到優盤主目錄下&#xff08;見下圖&#xff09; 全選并復制到U盤主目…

2025-06-13【視頻處理】基于視頻內容轉場進行分割

問題&#xff1a;從網上下載的視頻文件&#xff0c;是由很多個各種不同的場景視頻片段合并而成。現在要求精確的把各個視頻片段從大視頻里分割出來。 效果如圖&#xff1a;已分割出來的小片段 思考過程 難點在于檢測場景變化。為什么呢&#xff1f;因為不同的視頻情況各異&am…

ReentrantLock和RLock

文章目錄 前言一、 ReentrantLock&#xff08;單機鎖&#xff0c;Java 內置&#xff09;示例&#xff1a;方法詳解 二、RLock&#xff08;分布式鎖&#xff0c;Redisson 提供&#xff09;示例:方法詳解 三、 對比總結:四、 如何選擇&#xff1f; 前言 ReentrantLock 和 RLock 都…

thinkphp ThinkPHP3.2.3完全開發手冊

慣例配置 應用設定 APP_USE_NAMESPACE > true, // 應用類庫是否使用命名空間 3.2.1新增 APP_SUB_DOMAIN_DEPLOY > false, // 是否開啟子域名部署 APP_SUB_DOMAIN_RULES > array(), // 子域名部署規則 APP_DOMAIN_SUFFIX > , // 域名后綴 如果是…

Python Day50 學習(仍為日志Day19的內容復習)

補充&#xff1a;梳理超參數調整流程&#xff08;邏輯&#xff09; 超參數調節的流程邏輯可以總結為以下幾個步驟&#xff1a; 1. 明確目標 確定你要優化的模型和評估指標&#xff08;如準確率、F1值、AUC等&#xff09;。 2. 選擇要調節的超參數 列出模型中影響較大的超參數…

公司網絡變差的解決方法(固定IP地址沖突)

問題描述 最近公司網絡變差&#xff0c;不知道為什么。&#xff08;別的同事反饋的&#xff0c;本人沒有感覺變差&#xff0c;也是比較奇怪的現象&#xff09; 現象有視頻會議變卡等。 調查過程 1.領導給網絡公司打電話溝通&#xff0c;對面遠程看了下&#xff0c;不是設備問…

使用Prometheus+Grafana+Alertmanager+Webhook-dingtalk搭建監控平臺

一、監控平臺介紹 1.監控平臺簡述普羅米修斯四件套,分別為Prometheus、Grafana、Alertmanager、Webhook-DingTalk。Prometheus一套開源的監控&報警&時間序列數據庫的組合,由SoundCloud公司開發,廣泛用于云原生環境和容器化應用的監控和性能分析。其提供了通用的數據…

UR機器人解鎖關節扭矩控制:利用英偉達Isaac Lab框架,推動裝配自動化的Sim2Real遷移

在工業制造領域&#xff0c;機器人裝配長期依賴固定自動化模式&#xff0c;面臨部署成本高、適配性差等挑戰。多部件裝配是制造業、汽車及航空航天等行業中的核心環節。傳統裝配系統通常針對特定任務設計&#xff0c;依賴大量人工工程部署&#xff0c;靈活性不足&#xff0c;難…

ABB 605系列

系列概述 ABB Relion605系列是專為配電網設計的保護繼電器產品系列&#xff0c;代表了中低壓電力系統保護領域的技術基準。基于ABB在電力保護領域數十年的經驗&#xff0c;該系列集成了最新的數字信號處理技術和網絡通信能力&#xff0c;為變電站自動化提供了完整的解決方案。…

Python|GIF 解析與構建(6):手搓 tk 錄制工具

目錄 Python&#xff5c;GIF 解析與構建&#xff08;6&#xff09;&#xff1a;手搓 tk 錄制工具 一、工具功能概覽 二、核心架構設計 1. 幀率控制模塊 2. 屏幕捕獲模塊 3. 主應用模塊 三、關鍵技術解析 1. 屏幕捕獲技術 2. 幀率控制原理 3. 透明窗口實現 四、使用指…

在VBA中,提取word表格的文本時,通常有什么干擾符號,需要清除

標題 在VBA中&#xff0c;提取word表格的文本時&#xff0c;通常有什么干擾符號,需要清除 正文 解決問題提取word表格的文本時&#xff0c;通常有什么干擾符號,需要清除 在VBA中提取Word表格文本時&#xff0c;常見的干擾符號及其清除方法如下&#xff1a; ?? 一、主要干擾符…