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 规则全部清空。