背景
在做区块链互联网环境下交易测试时发现,不同网络环境对交易的执行有很大的影响;网络差的时候交易会丢失,卡住等,网络好或者局域网的时候则正常。因此需要一个模拟恶劣网络环境的工具。
本文介绍一个Linux下的为traffic control和netem工具。
其中,Netem 是 Linux 2.6 及以上内核版本提供的一个网络模拟功能模块。该功能模块可以用来在性能良好的局域网中,模拟出复杂的互联网传输性能,诸如低带宽、传输延迟、丢包等等情况。使用 Linux 2.6 (或以上) 版本内核的很多发行版 Linux 都开启了该内核功能,比如Fedora、Ubuntu、Redhat、OpenSuse、CentOS、Debian等等。tc 可以用来控制 netem 的工作模式。
使用
工具可完成如下功能:(故障模拟) 模拟时延,丢包,重复包,乱序。
TC实现原理
TC用于Linux内核的流量控制,主要是通过在输出端口处建立一个队列来实现流量控制。接收包从输入接口(Input Interface)进来后,经过流量限制(Ingress Policing)丢弃不符合规定的数据包,由输入多路分配器(Input De-Multiplexing)进行判断选择:如果接收包的目的是本主机,那么将该包送给上层处理;否则需要进行转发,将接收包交到转发块(Forwarding Block)处理。转发块同时也接