1. 程式人生 > >Facebook ATC弱網測試環境

Facebook ATC弱網測試環境

  使用者的網路環境千姿百態,弱網的、高延時的、丟包的。常有使用者反饋偶發bug,我們測試人員卻始終無法復現,根據使用者的描述,開發排查可能是網路不穩定導致的,所以急需建個弱網環境來測試。

弱網工具簡介:

  Augmented Traffic Control(ATC)是Facebook的一款開源的行動網路模擬工具,能很方便的模擬2g,3g,4g,delay,loss等各種網路場景。

硬體準備:

  我是搭建在本機的,所以需要用VM虛擬出一個Linux系統。

1.Ubuntu 16.04 LTS

2.USB無線網絡卡(晶片型號是RTL8188EUS)要確保無線網絡卡能支援AP(用iwlist檢視)

 

一、配置Ubuntu無線wifi熱點

  在操作之前先確認USB無線網絡卡和驅動都支援AP。

1.配置hostapd

  通過Hostapd可以將無線網絡卡切換為AP/Master模式,通過修改配置檔案,可以建立一個開放式的(不加密)的,WEP,WPA或WPA2的無線網路。

apt-get install hostapd

  新建hostapd檔案:vi /etc/hostapd/hostapd.conf

interface=wlx488ad2a0e0fe      //wifi裝置名稱
driver=nl80211
ssid=autotest
hw_mode
=g channel=10 macaddr_acl=0 auth_algs=3 wpa=2 wpa_passphrase=12345678 //密碼 wpa_key_mgmt=WPA-PSK wpa_pairwise=TKIP CCMP rsn_pairwise=TKIP CCMP

  啟動AP

hostapd -B /etc/hostapd/hostapd.conf

 此時應該有一個autotest的wifi可以連線,連線後處於“正在獲取IP”狀態。

 

2.配置dhcpd

   dhcp簡單來說是管理ip的

apt-get install
isc-dhcp-server

  開啟DHCP伺服器是為了讓終端能夠獲取到IP地址,分配的地址是私有的,因此只要不與公有的地址相沖突就可以,RFC 1918 為私有網路預留出了三個IP 地址塊,上述三個範圍內的地址不會在因特網上被分配,我們可以放心使用。

A 類:10.0.0.010.255.255.255
B 類:172.16.0.0172.31.255.255
C 類:192.168.0.0192.168.255.255

  我們需要配置/etc/dhcp/dhcpd.conf檔案,新增要分配的網段,指明分配的地址範圍,預設閘道器和DNS伺服器地址。在檔案最後我們新增以下內容。注意要分配的網段不能和主機ens33所處的網段相同。

subnet 192.168.0.0 netmask 255.255.255.0
  {
    range 192.168.0.2 192.168.0.10;
    option routers 192.168.0.1;
    option domain-name-servers 8.8.8.8;
  }

  配置無線網口wlx488ad2a0e0fe所處的網段,和上面的網段要一致。

ifconfig wlx488ad2a0e0fe 192.168.0.1 netmask 255.255.255.0

  接下來開啟dhcp,熱點會給接入的裝置分配ip,從 192.168.0.2~192.168.0.10 中隨機取一個。

service isc-dhcp-server start

  現在應該能連線上熱點,但還不能上網。

 

3.配置NAT

 我們需要開啟轉發功能,讓192.168.0.1/8網段的地址都通過網絡卡ens33轉發出去。

sysctl net.ipv4.ip_forward=1
iptables -t nat -A POSTROUTING -s 192.168.0.1/8 -o ens33 -j MASQUERADE

  手機連線wifi熱點,若可以正常上網,表示熱點配置成功了。

 

二、配置ATC

1.安裝和使用virtualenv建立python虛擬環境

apt install virtualenv
virtualenv project_ATC
cd project_ATC/bin
source activate

 

2.安裝python-pip工具

  用python3+嘗試安裝了一次,沒有成功。然後發現有些依賴第三方庫是python2+寫的,所以先確保你的python版本是python2.7,然後安裝對應的pip工具。

apt-get install python-pip

  通過pip下載安裝ATC需要的Django元件。

pip install atc_thrift 
pip install atcd 
pip install django-atc-api 
pip install django-atc-demo-ui 
pip install django-atc-profile-storage

 

3.修改ATC配置

  用命令建立一個Django工程

django-admin startproject ATC_UI

  編輯配置檔案 setting.py

cd ATC_UI/ATC_UI
vi settings.py

  在INSTALLED_APPS新增如下內容:

'rest_framework',
'atc_api',
'bootstrap_themes',
'django_static_jquery',
'atc_demo_ui',
'atc_profile_storage',

  ALLOWED_HOSTS 修改如下,‘*’允許所有ip訪問。

ALLOWED_HOSTS = ['*']

 

  編輯檔案urls.py

vi urls.py

  修改增加如下配置:

from django.views.generic.base import RedirectView
from django.conf.urls import include
 
urlpatterns = [
        url(r'^admin/',admin.site.urls),
        url(r'^api/v1/',include('atc_api.urls')),
        url(r'^atc_demo_ui/',include('atc_demo_ui.urls')),
        url(r'^api/v1/profiles/',include('atc_profile_storage.urls')),
        url(r'^$',RedirectView.as_view(url='/atc_demo_ui/', permanent=False)),
    ]

  最後切換到manage.py目錄,執行更新Django資料庫:

python manage.py migrate

 

 4.設定網絡卡

  --atcd-wan 引數  指定網絡卡作為公網連線, --atcd-lan 引數  指定此網絡卡作為內網連線。

atcd --atcd-wan ens33 --atcd-lan wlx488ad2a0e0fe

 

5.執行ATC_UI  

  然後就可以執行Django啦,runserver 引數 指定埠。

python manage.py runserver 0.0.0.0:8000

  

6.使用官方已經配好的網路配置檔案

  具體使用方法:

git clone https://github.com/facebookarchive/augmented-traffic-control.git
cd augmented-traffic-control
utils/restore-profiles.sh 192.168.0.1:8000

 

三、ATC使用方法

1.手機瀏覽器輸入192.168.0.1:8000,可以看到下面的UI

 

2.選擇需要的網路環境,點選“select”,然後點選最上面的“update shaping”,也可以自定義網路。然後你可以愉快的測試了,而且每部手機連線的網路互不影響,也就是說你設定了限速只對你自己有效,不會影響其他人。

 

 

 

 

部分參考github:https://github.com/facebookarchive/augmented-traffic-control