linux 弱网环境模拟,弱网模拟 tc/netem 辅助工具 pynetem

  • Post author:
  • Post category:linux


https://github.com/GuoTengda1993/pynetem

因为 tc/netem 只在 linux 系统中存在,所以只能在 Linux 系统中安装:

pip install pynetem

### 使用

有两种模式:命令行模式、Web 模式,两种模式下每次传入新规则都会将旧规则替换掉。

命令行模式

输入pynetem -h可以查看帮助信息,参数和 tc/netem 基本一致,只使用上有些许区别,点击此链接即可查看 tc/netem 的相关文档:netem

向远端 linux 服务器发送需添加如下参数:

–host 远端服务器IP地址

–usrname 用户名

–password 密码

使用示例:

# 该命令将 eth0 网卡的传输设置为 100ms ,同时,大约有 30% 的包会延迟 ± 10ms 发送

pynetem -i eth0 –delay=100ms,10ms,30%

# 该命令将 eth0 网卡的传输设置为随机丢掉 1% 的数据包,成功率为 30%

pynetem -i eth0 –loss=1%,30%

# 该命令将 eth0 网卡的传输设置为随机产生 1% 的重复数据包

pynetem -i eth0 –duplicate=1%

# 该命令将 eth0 网卡的传输设置为随机产生 0.2% 的损坏的数据包 。 (内核版本需在2.6.16以上)

pynetem -i eth0 –corrupt =0.2%

# 该命令将 eth0 网卡的传输设置为:有 25% 的数据包(50%相关)会被立即发送,其他的延迟 10ms

pynetem -i eth0 –delay=10ms –reorder=25%,50%

# 该命令将 eth0 网卡的传输设置为 延迟100ms,同时限定网卡的出速率

pynetem -i eth0 –delay=100ms –rate=256kbit

# 该命令将 eth0 网卡的传输设置为 在符合CIDR条件下延迟100ms&限定网卡的出速率

pynetem -i eth0 –delay=100ms –rate=256kbit –dst=10.10.10.10/32

Web 模式

运行此模式可以对外提供接口,默认开启8899端口,也可以指定其它端口。

pynetem –web –port=9000

共有 8 个 API 可以调用:

[GET] /pynetem/help — Get demo post data and simple description

[GET] /pynetem/listInterfaces — Get interfaces name of host

[GET] /pynetem/getRules?eht= — Get qdisc rules by interface

[GET/DELETE] /pynetem/clear?eth= — Clear all rules

[POST] /pynetem/setRules?eth= — Set tc qdisc rule

[POST] /pynetem/brctl/addbr — Set bridge, the bridge name is pynetem_bridge by defaut

[GET/DELETE] /pynetem/brctl/delbr — Delete pynetem_bridge

[POST] /pynetem/brctl/addif — Add interface(s) to pynetem_bridge

请求体中,如果设置参数为None或””,则会忽略此参数,请求体示例如下:

[POST] /pynetem/setRules?eth= {“delay”:”100ms 10ms 25%”,”distribution”:”normal”,”reorder”:”25% 50%”,”loss”:”0.3% 25%”,”duplicate”:”1%”,”corrupt”:”0.1%”,”rate”:”256kbit”,”buffer”:1600,”limit”:3000,”dst”:”10.10.10.0/24″}

配置 Linux 网桥:[POST] /pynetem/brctl/addbr

stp is “on” by default.

{“interfaces”:[“eth0″,”eth1″],”stp”:”on”}

需要注意的是,当按下ctrl + c关停 web 服务时,会自动将所有网卡接口下的所有 qdisc 规则全部清空。