如何避免 ARP Flux 問題

在 Debain9 默認(rèn)配置下,只要 ARP 請求中的目標(biāo) IP 配置在本機(jī),無論目標(biāo) IP 是否配置在收到 ARP 請求包的網(wǎng)口上,Linux 收包網(wǎng)口都會以自身 MAC 地址發(fā)送 ARP 響應(yīng)。當(dāng)一臺主機(jī)多網(wǎng)口在同子網(wǎng)的情況下,一個 APR 請求就會收到多個 ARP 響應(yīng),這種情況被稱為 ARP Flux。它可能會造成嚴(yán)重問題(我們在使用某些品牌交換機(jī)時確實遇到了)。

最常見的避免 ARP Flux 方案是將網(wǎng)口的 arp_ignore 置為 1 來避免響應(yīng)目標(biāo) IP 不屬于網(wǎng)口自身的 APR 請求。這樣做有一個缺陷:在某些場景下降低了網(wǎng)絡(luò)的連通的成功率,比如在 docker 使用 macvlan 又需要與主機(jī)通信的情況下。

另一種解決方案是將網(wǎng)口的 arp_filter 置為 1,kernel 會根據(jù)反向路由來控制由哪個網(wǎng)口響應(yīng) arp 請求(通常只有一個網(wǎng)口)。

還有一種方案是將網(wǎng)口的 rp_filter 置為 1,它是 Centos7 上的默認(rèn)配置。對于每個進(jìn)來的數(shù)據(jù)包, kernel會根據(jù)路由規(guī)則表校驗收包網(wǎng)口是不是最佳應(yīng)答網(wǎng)口,如果不是,數(shù)據(jù)包會被丟掉。

根據(jù)影響最小原則,這里推薦變更 arp_filter 來避免 ARP Flux 問題。當(dāng)然試具體情況而變。

參考連接:
ether-arp-flux
Networking Tuning Tips
ARP響應(yīng)實例研究
ip-sysctl

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容