全部產品
Search
文件中心

Elastic Compute Service:網路延遲演練

更新時間:Apr 19, 2025

網路延遲直接影響應用程式和服務的響應速度,過高的網路延遲會影響使用者的使用體驗。網路流量增大、線路不穩定等情況都會增加網路延遲。通過此演練情境驗證系統在網路延遲時的警示和恢複情況。

使用限制

該演練情境需要使用tc(Traffic Control)工具及其依賴的核心netem組件。

  • 如系統缺少tc工具,請執行sudo yum install -y iproute-tcsudo apt-get install -y iproute2安裝,或者執行外掛程式時指定相關參數自動安裝。

  • 如系統核心缺少netem組件,如CentOS,可執行sudo yum install kernel-modules-extra安裝軟體包並重啟。

    警告

    注意安裝kernel-modules-extra會修改核心版本,請謹慎操作,建議使用其他動作系統的ECS進行演練。

實現原理

本方案使用雲助手外掛程式ACS-ECS-NetDelay,使用tc(Traffic Control)工具和netem組件對網卡增加特定規則,實現對Linux核心流量控制。該外掛程式可實現對全域IP或僅針對單個IP進行限制,其中雲助手網段100.100.0.0/16不會受到影響。

使用指南

演練準備

請確保您的ECS執行個體已安裝雲助手Agent,並且雲助手狀態正常。具體操作,請參見查看雲助手狀態及異常狀態處理

故障注入

  1. 登入ECS執行個體。

    具體操作,請參見使用Workbench工具以SSH協議登入Linux執行個體

  2. 使用具有sudo存取權限的使用者,運行雲助手外掛程式ACS-ECS-NetDelay

    sudo acs-plugin-manager --exec --plugin ACS-ECS-NetDelay --params inject,dev=eth0,[time=paramA],[jitter=paramB],[target-ip=paramC],[replace=paramD],[duration=paramE],[install-tc=paramF]

    []內為可選故障注入參數,參數說明:

    • dev(必填):需要注入的網卡,如eth0,可執行ifconfig查看當前系統的網卡。

    • time(可選):延遲時間,單位為ms,預設100。

    • jitter(可選):抖動範圍,單位為ms,預設10。

    • target-ip(可選):預期產生影響的目標IP,預設為空白,表示對所有IP增加延遲,如指定目標IP,則只有該IP會受到影響。

    • replace(可選):如網卡已有設定的tc規則,注入時會產生衝突導致失敗。如確定對原有規則進行覆蓋,可指定值為true。

    • duration(可選):期間,單位為s,預設為300。

    • install-tc(可選):如系統缺少tc工具,可指定該參數為true自動安裝,預設false

    顯示如下所示時,說明雲助手外掛程式ACS-ECS-NetDelay執行成功。

    image

  3. 通過ping目標網路,查看故障注入是否成功。

故障恢複

  • 方法一:等待逾時自動回復。

  • 方法二:執行故障恢複命令。

    sudo acs-plugin-manager --exec --plugin ACS-ECS-NetDelay --params recover

演練案例

  1. 類比業務訪問目標網路。

    ping www.taobao.com

    本樣本以訪問www.taobao.com為例進行說明,返回樣本如下:

    image

  2. 執行故障注入。

    sudo acs-plugin-manager --exec --plugin ACS-ECS-NetDelay --params inject,dev=eth0,time=1000,jitter=30,duration=120

    對目標IP,增加1000ms延遲,抖動30ms。

    image

  3. 查看注入效果。

    查看網路延遲情況,ping命令在注入後延遲增加1000ms,產生的延遲在1000±30ms範圍內。

    image

  4. 等待故障恢複。

    注入逾時後,延遲降低回原有水平,網路恢複。

    image