Linux模拟复杂网络环境下的传输(netem和tc)

2023-11-27 16:32

本文主要是介绍Linux模拟复杂网络环境下的传输(netem和tc),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!


在进行网络服务的测试时,有时需要模拟一些异常的网络情况,例如网络延时长、丢包、网络地址连接不通等。
在Linux下,可以通过tc工具来模拟各种网络情况;通过iptables禁止访问某个网络地址。

一、netemtc介绍

netem 是  Linux 2.6 及以上内核版本提供的一个网络模拟功能模块。该功能模块可以用来在性能良好的局域网中,模拟出复杂的互联网传输性能,诸如低带宽、传输延迟、丢包等等情况。

    使用  Linux 2.6 (或以上 版本内核的很多发行版  Linux 都开启了该内核功能,比如 Fedora Ubuntu Redhat OpenSuse CentOS Debian等等。

tc 是  Linux 系统中的一个工具,全名为 traffic control(流量控制)。 tc 可以用来控制  netem 的工作模式,也就是说,想要使用  netem ,则需要内核开启了  netem,而且安装了  tc工具


tc控制的是发包动作,不能控制收包动作。它直接对物理接口生效,如果控制了物理的 eth0,那么逻辑网卡(比如 eth0:1)也会受到影响,反之则不行,控制逻辑网卡是无效的。

二、模拟延迟传输

 eth0 网卡的传输设置为延迟100毫秒发送。
 $ tc  qdisc  add  dev  eth0  root  netem  delay  100ms  

真实的情况下,延迟值不会这么精确,会有一定的波动,下面命令模拟带有波动性的延迟值:
 $ tc  qdisc  add  dev  eth0  root  netem  delay  100ms  10ms

该命令将  eth0 网卡的传输设置为延迟  100ms ± 10ms  90 ~ 110 ms 之间的任意值)发送。
由于各个包的延迟值不通,也会在一定程度上打乱发包的次序。


还可以更进一步加强这种波动的随机性,将  eth0 网卡的传输设置为  100ms ,同时,大约有 30%的包会延迟  ± 10ms 发送
 $ tc  qdisc  add  dev  eth0  root  netem  delay  100ms  10ms  30%

三、模拟网络丢包

 eth0 网卡的传输设置为随机丢掉 1% 的数据包。
 $ tc  qdisc  add  dev  eth0  root  netem  loss  1%  

也可以设置丢包的成功率,将  eth0 网卡的传输设置为随机丢掉  1% 的数据包,成功率为 30% 
 $ tc  qdisc  add  dev  eth0  root  netem  loss  1%  30%

四、模拟包重复

 eth0 网卡的传输设置为随机产生  1% 的重复数据包。
 $ tc  qdisc  add  dev  eth0  root  netem  duplicate 1% 

五、模拟数据包损坏

 eth0 网卡的传输设置为随机产生 0.2% 的损坏的数据包。 (内核版本需在2.6.16以上)
 $ tc  qdisc  add  dev  eth0  root  netem  corrupt  0.2% 

六、模拟数据包乱序

 eth0 网卡的传输设置为:25%的数据包(50%相关)会被立即发送,其他的延迟10秒。
 $ tc  qdisc  change  dev  eth0  root  netem  delay  10ms   reorder  25%  50%

七、一个实例
step1:使用ifconfig命令查看你的网卡信息,如:eth0
step2:将网卡加入监控列表 
$ sudo tc qdisc add dev eth0 root netem
step3:
设置丢包率 
$ sudo tc qdisc change dev eth0 root netem loss 0.5% 
设置重发
$ sudo tc qdisc change dev eth0 root netem duplicate 1%
设置发乱序包
$ sudo tc qdisc change dev eth0 root netem gap 5 delay 10ms


如果想让网络恢复正常,只需要删除监控,或将设置的值相应归0即可。

例如,设置延时
$ sudo tc qdisc add dev eth0 root netem delay 4s

取消延时
$ sudo tc qdisc del dev eth0 root netem delay 4s



八、禁止访问一个IP
如果要禁止访问一个IP,不使用tc,而是用iptables。iptalbes可以简单理解为linux下的防火墙,控制网络访问。
1、禁止访问10.237.0.1
$ iptables -A OUTPUT -d 10.237.0.1 -j REJECT


2、查看规则
$ iptables -L OUTPUT -n
Chain OUTPUT (policy ACCEPT)
target     prot opt source               destination         
REJECT     all  --  0.0.0.0/0            10.237.0.1        reject-with icmp-port-unreachable


3、查看规则号
$ iptables -L OUTPUT -n --line-numbers
Chain OUTPUT (policy ACCEPT)
num  target     prot opt source               destination         
1    REJECT     all  --  0.0.0.0/0            10.237.0.1        reject-with icmp-port-unreachable


4、删除规则
$ iptables -D OUTPUT 1



参考:

http://www.dbafree.net/?p=180



这篇关于Linux模拟复杂网络环境下的传输(netem和tc)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/428013

相关文章

通过Docker容器部署Python环境的全流程

《通过Docker容器部署Python环境的全流程》在现代化开发流程中,Docker因其轻量化、环境隔离和跨平台一致性的特性,已成为部署Python应用的标准工具,本文将详细演示如何通过Docker容... 目录引言一、docker与python的协同优势二、核心步骤详解三、进阶配置技巧四、生产环境最佳实践

防止Linux rm命令误操作的多场景防护方案与实践

《防止Linuxrm命令误操作的多场景防护方案与实践》在Linux系统中,rm命令是删除文件和目录的高效工具,但一旦误操作,如执行rm-rf/或rm-rf/*,极易导致系统数据灾难,本文针对不同场景... 目录引言理解 rm 命令及误操作风险rm 命令基础常见误操作案例防护方案使用 rm编程 别名及安全删除

Linux下MySQL数据库定时备份脚本与Crontab配置教学

《Linux下MySQL数据库定时备份脚本与Crontab配置教学》在生产环境中,数据库是核心资产之一,定期备份数据库可以有效防止意外数据丢失,本文将分享一份MySQL定时备份脚本,并讲解如何通过cr... 目录备份脚本详解脚本功能说明授权与可执行权限使用 Crontab 定时执行编辑 Crontab添加定

SpringBoot 多环境开发实战(从配置、管理与控制)

《SpringBoot多环境开发实战(从配置、管理与控制)》本文详解SpringBoot多环境配置,涵盖单文件YAML、多文件模式、MavenProfile分组及激活策略,通过优先级控制灵活切换环境... 目录一、多环境开发基础(单文件 YAML 版)(一)配置原理与优势(二)实操示例二、多环境开发多文件版

使用docker搭建嵌入式Linux开发环境

《使用docker搭建嵌入式Linux开发环境》本文主要介绍了使用docker搭建嵌入式Linux开发环境,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面... 目录1、前言2、安装docker3、编写容器管理脚本4、创建容器1、前言在日常开发全志、rk等不同

Debian 13升级后网络转发等功能异常怎么办? 并非错误而是管理机制变更

《Debian13升级后网络转发等功能异常怎么办?并非错误而是管理机制变更》很多朋友反馈,更新到Debian13后网络转发等功能异常,这并非BUG而是Debian13Trixie调整... 日前 Debian 13 Trixie 发布后已经有众多网友升级到新版本,只不过升级后发现某些功能存在异常,例如网络转

linux系统上安装JDK8全过程

《linux系统上安装JDK8全过程》文章介绍安装JDK的必要性及Linux下JDK8的安装步骤,包括卸载旧版本、下载解压、配置环境变量等,强调开发需JDK,运行可选JRE,现JDK已集成JRE... 目录为什么要安装jdk?1.查看linux系统是否有自带的jdk:2.下载jdk压缩包2.解压3.配置环境

Linux搭建ftp服务器的步骤

《Linux搭建ftp服务器的步骤》本文给大家分享Linux搭建ftp服务器的步骤,本文通过图文并茂的形式给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录ftp搭建1:下载vsftpd工具2:下载客户端工具3:进入配置文件目录vsftpd.conf配置文件4:

Java实现复杂查询优化的7个技巧小结

《Java实现复杂查询优化的7个技巧小结》在Java项目中,复杂查询是开发者面临的“硬骨头”,本文将通过7个实战技巧,结合代码示例和性能对比,手把手教你如何让复杂查询变得优雅,大家可以根据需求进行选择... 目录一、复杂查询的痛点:为何你的代码“又臭又长”1.1冗余变量与中间状态1.2重复查询与性能陷阱1.

Linux实现查看某一端口是否开放

《Linux实现查看某一端口是否开放》文章介绍了三种检查端口6379是否开放的方法:通过lsof查看进程占用,用netstat区分TCP/UDP监听状态,以及用telnet测试远程连接可达性... 目录1、使用lsof 命令来查看端口是否开放2、使用netstat 命令来查看端口是否开放3、使用telnet