802.11 Wi-Fi 競爭機制深度分析:CSMA/CA 與 DCF

802.11 Wi-Fi 競爭機制深度分析:CSMA/CA 與 DCF

一、核心機制:CSMA/CA(載波偵聽多路訪問/沖突避免)

傳統以太網使用 CSMA/CD(沖突檢測),但無線環境中無法實現沖突檢測,因此802.11采用 CSMA/CA(沖突避免)。

關鍵組件:
  1. 載波偵聽:物理層(PHY)和虛擬載波偵聽(NAV)
  2. 幀間間隔(IFS):優先級控制機制
  3. 隨機退避:沖突避免核心
  4. ACK機制:可靠傳輸保障
有幀發送
信道空閑?
等待DIFS
啟動退避計時器
時隙空閑?
計數器減1
計數器=0?
發送幀
等待信道空閑
等待ACK
收到ACK?
成功
重傳計數器+1
CW=CWmin?
倍增CW

二、幀間間隔(IFS)優先級控制

不同IFS提供不同優先級訪問權:

IFS類型時長(典型值)優先級用途
SIFS10μs最高ACK, CTS, 分片突發
PIFS30μsPCF模式輪詢
DIFS50μs普通數據幀傳輸
AIFS可變可調QoS增強(EDCA)

三、隨機退避算法

沖突避免的核心機制:

Yes
Yes
Yes
No
開始
信道空閑達DIFS?
選擇退避時隙數:
Backoff = Random(0, CW)
等待時隙空閑
時隙空閑?
Backoff--
Backoff=0?
發送幀
凍結計數器
等待信道空閑

競爭窗口(CW)變化規則

  • 初始值:CW = CWmin
  • 每次失敗:CW = (CW+1) × 2 - 1
  • 上限值:CW ≤ CWmax
  • 成功傳輸后:CW = CWmin

CW值示例(802.11a/g)

嘗試次數CWminCWmax隨機范圍
11510230-15
23110230-31
36310230-63
6+102310230-1023

四、虛擬載波偵聽:NAV(網絡分配向量)

工作原理

  1. 每個站點維護NAV計數器
  2. 收到幀頭中的"Duration"字段時更新NAV
  3. NAV > 0 時認為信道忙
發送站接收站鄰居站RTS(Duration=傳輸總時間)更新NAV = RTS.DurationCTS(Duration=剩余時間)更新NAV = CTS.DurationDATAACKNAV到期,可競爭信道發送站接收站鄰居站

五、隱藏節點問題與RTS/CTS機制

問題場景:
信號覆蓋
信號覆蓋
無法檢測C
節點A
AP
節點C
RTS/CTS解決方案:
發送站AAP隱藏站CRTS(Duration)CTS(Duration)收到CTS,設置NAV發送數據ACK發送站AAP隱藏站C

六、DCF(分布式協調功能)完整流程

站點1信道站點2接入點等待DIFS空閑退避計數(3時隙)退避計數(5時隙)STA1計數器先歸零發送數據幀SIFS后回復ACK凍結計數器(剩余2時隙)新幀需重新競爭繼續退避計數站點1信道站點2接入點

七、性能優化機制

  1. 幀聚合(A-MPDU):

    • 多個幀+單次退避+塊ACK
    • 減少協議開銷
  2. TXOP(傳輸機會):

    timelinetitle TXOP工作機制節點A : DIFS + 退避 : 數據1 : SIFS : 數據2 : SIFS : ACK其他節點 : 等待NAV超時
    
  3. EDCA(增強型分布式信道訪問):

    • QoS優先級分類:
    訪問類別簡稱AIFSNCWminCWmaxTXOP限制
    語音AC_VO2373.264ms
    視頻AC_VI27156.016ms
    盡力而為AC_BE31510230
    背景AC_BK71510230

八、數學建模:吞吐量分析

飽和吞吐量公式
S=Ps?Ptr?E[P](1?Ptr)σ+PtrPsTs+Ptr(1?Ps)Tc S = \frac{P_s \cdot P_{tr} \cdot E[P]}{(1-P_{tr})\sigma + P_{tr}P_s T_s + P_{tr}(1-P_s)T_c} S=(1?Ptr?)σ+Ptr?Ps?Ts?+Ptr?(1?Ps?)Tc?Ps??Ptr??E[P]?

其中:

  • PsP_sPs?:成功傳輸概率
  • PtrP_{tr}Ptr?:至少一個站傳輸的概率
  • E[P]E[P]E[P]:有效載荷平均長度
  • TsT_sTs?:成功傳輸時隙長度
  • TcT_cTc?:沖突時隙長度
  • σ\sigmaσ:空時隙長度

優化方向

  • 動態調整CW大小
  • 基于負載預測的退避算法
  • 機器學習優化競爭參數

結論

802.11的競爭機制通過CSMA/CA+DCF+隨機退避的組合,結合物理/虛擬載波偵聽優先級控制,有效解決了無線環境中的隱藏節點、暴露節點等問題。現代優化如TXOP、EDCA和幀聚合顯著提升了高密度場景下的網絡效率。理解這些機制對Wi-Fi網絡設計和故障診斷至關重要。

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

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

相關文章

【Go語言-Day 36】構建專業命令行工具:`flag` 包入門與實戰

Langchain系列文章目錄 01-玩轉LangChain:從模型調用到Prompt模板與輸出解析的完整指南 02-玩轉 LangChain Memory 模塊:四種記憶類型詳解及應用場景全覆蓋 03-全面掌握 LangChain:從核心鏈條構建到動態任務分配的實戰指南 04-玩轉 LangChai…

C語言——深入理解指針(四)

C語言——深入理解指針(四) 數組名的意義sizeof(數組名),且數組名單獨放在sizeof內部,則這里的數組名表示整個數組,計算的是整個數組的大小&數組名,這里的數組名表示的是整個數組…

LeetCode 刷題【42. 接雨水】

42. 接雨水 自己做 解&#xff1a;雙指針左右分割容器 class Solution { public:int trap(vector<int>& height) {int res 0;int len height.size();if(len < 2) //構不成一個容器了&#xff0c;直接返回return res;int end len - 1; //右邊界int…

網絡的基本概念、通信原理以及網絡安全問題

目錄 1、 什么是網絡&#xff1f; &#xff08;1&#xff09;網絡的概念與本質 &#xff08;2&#xff09;電壓信號的合并與抵消 &#xff08;3&#xff09;電壓的本質 2、中轉設備 &#xff08;1&#xff09;背景 &#xff08;2&#xff09;中轉設備的處理能力與編程能…

Windows下使用WSL2創建Ubuntu子系統(更改安裝位置與啟動圖形桌面)

Windows下使用WSL2創建Ubuntu子系統&#xff08;更改安裝位置與啟動圖形桌面&#xff09; 本文介紹如何使用WSL2創建Ubuntu子系統&#xff0c;并更改安裝位置到其他磁盤&#xff0c;并啟動圖形桌面Xfce4。 WSL 版本: 2.5.7.0 系統版本: Windows11 23H2 相關工具&#xff1a;Mo…

時間泄漏 TemporalLeakage

時間泄漏 TemporalLeakage: 就是后續有事件發生&#xff0c;然后才有了這個結果&#xff0c;但是在該事件發生之前&#xff0c;不應該預測該結果。 Temporal Leakage 問題是往往導致縱向Planning不“果斷”。 解決方案&#xff1a;人工標注出時間發生的時刻 真值只監督時間發生…

獨立書店數字化轉型:絕版書修復檔案系統與讀者閱讀行為分析營銷平臺

在電商沖擊與閱讀習慣變遷的雙重壓力下&#xff0c;獨立書店正遭遇 “舊書修復難、新書賣不動” 的生存困境。傳統模式中&#xff0c;絕版書修復依賴老師傅經驗&#xff0c;單本修復周期長達 2 周&#xff0c;損耗率超 30%&#xff1b;營銷缺乏數據支撐&#xff0c;導致客流年均…

const修飾指針用法詳解

目錄 一、const修飾變量 繞過const限制的問題 二、const修飾指針變量 1、無const修飾的指針 2、const放在*左邊 3、const放在*右邊 4、*兩邊都有const 三、使用建議 四、記憶技巧 一、const修飾變量 在C語言中&#xff0c;變量默認是可修改的。如果我們希望某個變量不能…

pcl法線估計的踩坑

1&#xff0c;normalestimation對點云法線的評估&#xff0c;只輸出法線向量&#xff0c;并不輸出xyz值。如果輸出類型是pointnormal&#xff0c;那么這點云的法向量有值&#xff0c;xyz值都是02&#xff0c;添加點云xyz數據。可以使用 pcl::concatenatefields(*a,*b,*c)函數p…

利用Minicsv庫解析csv文件的c程序及讀入測試

上午的c程序寫入xlsx較快但不正確&#xff0c;python程序雖正確但過慢。所以找了一個全部源程序加起來不到4K字節的C語言csv解析庫Minicsv&#xff0c;來改寫&#xff0c;改寫結果如下&#xff1a; #include <stdio.h> #include <stdlib.h> #include <string.h…

企微用戶部門同步HRS系統

企微用戶導入HR系統流程說明 概述 本文檔詳細說明了WechatUserImportServiceImpl.importWechatUsersToHrs()方法的業務流程和實現邏輯。該方法負責將企業微信用戶數據同步導入到HR管理系統中&#xff0c;包括員工信息、工作信息和任職記錄的創建與更新。 主要功能 數據同步…

告別傳統SEO!擁抱下一代流量密碼:生成式引擎優化(GEO)實戰指南

前言&#xff1a;為什么你的“最佳實踐”SEO正在失效&#xff1f;你是否發現&#xff0c;即使嚴格遵循了谷歌自2019年以來的所有“最佳實踐”&#xff0c;你的技術博客或產品文檔的流量依舊增長乏力&#xff0c;甚至不升反降&#xff1f;你不是一個人。問題在于&#xff0c;游戲…

week1-[一維數組]傳送

week1-[一維數組]傳送 題目描述 有 nnn 個傳送門&#xff0c;從第 iii 個傳送門進去后會被傳送到第 aia_iai? 個傳送門&#xff0c;進而被傳送到第 aaia_{a_i}aai?? 個傳送門&#xff0c;如此一直下去……小 A 想知道從第 kkk 個傳送門進去后&#xff0c;能不能回到第 kkk 個…

【18】目心智能——目心智能 嵌入式一面 ,校招,面試問答記錄

目心智能——目心智能 嵌入式一面 &#xff0c;校招&#xff0c;面試問答記錄 1 簡單自我介紹2 你做了這么多算法&#xff0c;為什么不找算法的&#xff1f;3 我們主要還是軟件開發&#xff0c;不做結構設計4 模電知識6 CSDN應該附鏈接在簡歷上&#xff0c;稍后發給我&#xff…

C++第二十課:快遞運費計算器 / 黑白配+石頭剪刀布小游戲

快遞運費計算器幫一家快遞站點開發一個快遞運費計算器&#xff0c;快遞站點人員只需要輸入包裹重量和地點編號即可計算出對應的運費。假設快遞費計算規則如下&#xff1a;首重&#xff1a;3公斤 3公斤以內&#xff1a;1.東三省/寧夏/青海/海南&#xff1a;12元&#xff0c;2.新…

網絡安全藍隊常用工具全景與實戰指南

摘要 在現代信息系統的安全防護中&#xff0c;藍隊承擔著防御、檢測、響應和持續改進的核心職責。要實現高效、可持續的防御能力&#xff0c;藍隊需要一整套成熟、可靠的工具集來進行威脅情報收集、日志分析、入侵檢測、漏洞評估、端點防護、網絡流量監控、事件響應與取證等工作…

基于 Flink 的淘寶實時數據管道設計:商品詳情流式處理與異構存儲

引言在電子商務領域&#xff0c;實時數據處理能力已成為企業核心競爭力的重要組成部分。淘寶作為中國領先的電商平臺&#xff0c;每天產生海量的商品數據&#xff0c;這些數據需要被實時處理、分析并分發到各種存儲系統中&#xff0c;以支持搜索、推薦、庫存管理等關鍵業務。本…

面試題:【多線程問題,三個線程A,B,C;C線程依賴B線程的結果執行,怎么控制】

在 Java 中&#xff0c;若需要控制線程間的依賴關系&#xff08;如 C 線程依賴 B 線程的結果&#xff09;&#xff0c;可以通過以下幾種方式實現&#xff1a; 方案 1&#xff1a;使用 CountDownLatch CountDownLatch 是一個同步工具類&#xff0c;允許一個或多個線程等待其他線…

React useMemo 深度指南:原理、誤區、實戰與 2025 最佳實踐

把“為什么用、怎么用、用錯了怎么辦”一次講透&#xff0c;附 React 19 自動優化前瞻。一、useMemo 是什么&#xff1f; 一句話&#xff1a; useMemo 記住&#xff08;緩存&#xff09;昂貴計算結果&#xff0c;只在依賴變化時重新計算。 const memoValue useMemo(() > {…

[ HTML 前端 ] 語法介紹和HBuilderX安裝

目錄 一. HTML 1.概述 2. 安裝前端開發工具 (1)HBuilderX下載 (2)創建html項目和使用 3. HTML基礎 1.標簽 (1).標簽定義: (2).標簽結構: (3).標簽屬性: 2.常用標簽: 3.特殊符號: 4.表格(table) (1)基本標簽: (2)基本結構: (3)表格屬性: 5.表單(form) (1). 表單概述…