linux tc流量控制
tc流量控制
项目背景
- vintage3.0接口lookupforupdage增加一个策略,当带宽流量tx或rx超过40%,75%随机返回304;超过60%,此接口均返回304
- 为了对测试机器进行流量控制,使用了tc:设置网络传输速率;传输大文件:产生网络流量
生成大文件
dd if=/dev/zero of=test bs=1M count=10000
会生成一个10000M的test文件,文件内容为全0
文件比较大,同机房直接传输也需要几分钟
注意:文件传输需要在同机房,可以打满带宽;如果跨机房的话,无法打满带宽,也就十几兆左右。
tc简介
暂时没弄明白,请参考http://blog.csdn.net/daniel117/article/details/17350243
流量控制目标机器
假设eth0是服务器的外网网络接口(可以用ifconfig查一下目标机器使用的外网网络接口)。tc队列添加设备接口root为最上层句柄,标记类型默认使用1的class
tc qdisc add dev eth0 root handle 1: htb default 1
解释:无论是队列还是class,filter,都有ID之类的标志符,一般都有parent(父,上层的),因为qdisc在顶部,所有parent无,用root字样标识,ID用1: 来标志;default 1表示当某个ip流不满足任何已设定的filter规则时,将自动归入class 1 中在qdisc下建立一个class,来制定eth0控制通过本机到外网的速度
tc class add dev eth0 parent 1: classid 1:1 htb rate 100mbit ceil 1000mbit
解释:为eth0下的root队列1:0添加分类并命名为1:1,类型为htb,速度为100mbit,最大可以到1000mbit。
特别说明:网卡计量用的bit,和我们通常计量的byte换算关系是8:1,所以100mbit的速率是12M,如果想设置流量为25M,rate为200mbit,如下tc class add dev eth0 parent 1: classid 1:1 htb rate 200mbit ceil 1000mbit
此处控制的流量是send(发送)即tx,如果想控制rx(接收)流量,需要设置发送流量的机器;比如想设置接收流量25M,那么需要设置发送流量机器tc rate 200mbit
实践
- 基于vintage项目背景,将vintage-server部署在10.13.1.135,启动vintage-server服务
模拟tx(send)流量超过40%,如48M
- 对10.13.1.135进行流量控制
tc qdisc add dev eth0 root handle 1: htb default 1
tc class add dev eth0 parent 1: classid 1:1 htb rate 400mbit ceil 1000mbit- 10.13.1.135创建一个大文件 dd if=/dev/zero of=test bs=1M count=10000
- 在10.13.1.134接收大文件test,
nc -l 1234 >test - 在10.13.1.135发送大文件test,
nc 10.13.1.134 1234
大文件传输期间就可以进行自己的测试任务
模拟rx(receive)流量超过60%,如72M
- 对10.13.1.134进行流量控制
tc qdisc add dev eth0 root handle 1: htb default 1
tc class add dev eth0 parent 1: classid 1:1 htb rate 400mbit ceil 1000mbit
* 10.13.1.134发送大文件
* 10.13.1.135接收大文件
自动化工具
待续
linux tc流量控制的更多相关文章
- Linux TC 流量控制介绍
前段时间在做一些测试的时候接触到了Linux tc,因为需要对数据包添加延迟,用到了tc中的netem.添加简单的延迟非常简单,像这样一条命令就搞定了:$ tc qdisc add dev eth0 ...
- Linux TC流量控制HOWTO中文版
<本文摘自Linux的高级路由和流量控制HOWTO中文版 第9章节>网人郭工进行再次编译: 利用队列,我们可以控制数据发送的方式.记住我们只能对发送数据进行控制(或称为整形).其实,我们无 ...
- Linux TC的ifb原理以及ingress流控-转
原文:http://www.xuebuyuan.com/2961303.html 首先贴上Linux内核的ifb.c的文件头注释: The purpose of this driver is ...
- Linux TC (traffic control)
在着手学习TC采用如下单位来描述带宽: mbps = 1024 kbps = 1024 * 1024 bps => byte/s mbit = 1024 kbit => kilo bit/ ...
- Linux TC(Traffic Control)框架原理解析
近日的工作多多少少和Linux的流控有点关系.自打几年前知道有TC这么一个玩意儿而且多多少少理解了它的原理之后,我就没有再动过它,由于我不喜欢TC命令行,实在是太繁琐了.iptables命令行也比較繁 ...
- Linux网络流量控制工具—Netem
第一篇:概念篇 Netem 是 Linux 2.6 及以上内核版本提供的一个网络模拟功能模块.该功能模块可以用来在性能良好的局域网中,模拟出复杂的互联网传输性能,诸如低带宽.传输延迟.丢包等等情况.使 ...
- Linux TC基于CBQ队列的流量管理范例
参考了TC的很多文档,自己也整理了一篇配置记录.在实际使用过程中效果还不错,在此分享给大家以备参考.环境:局域网规模不是很大40多台机器. NAT共享上网(内网:eth0 外网:eth2)CBQ是通过 ...
- linux下使用tc(Traffic Control) 流量控制命令模拟网络延迟和丢包
目录 TC案例 TC常用命令 TC安装 TC原理介绍 TC规则 TC操作原理 TC命名规则 TC单位 TC命令 TC案例 如何使用tc模拟网络延迟和丢包 修改网络延时: sudo tc qdisc ...
- linux 下使用 tc 模拟网络延迟和丢包(转)
1 模拟延迟传输简介 netem 与 tc: netem 是 Linux 2.6 及以上内核版本提供的一个网络模拟功能模块.该功能模块可以用来在性能良好的局域网中,模拟出复杂的互联网传输性能,诸如低带 ...
随机推荐
- rsync配置文件
vim /etc/rsyncd.conf motd file = /etc/rsyncd.motd #设置服务器信息提示文件,在该文件中编写提示信息 transfer logging = yes #开 ...
- 算法笔记4.3递归 问题 B: 数列
题目描述 编写一个求斐波那契数列的递归函数,输入n 值,使用该递归函数,输出如下图形(参见样例). 输入 输入第一行为样例数m,接下来有m行每行一个整数n,n不超过10. 输出 对应每个样例输出要求的 ...
- django框架进阶-CSRF认证
############################################### """ django中csrf的实现机制 #第一步:django第一次响应 ...
- [LC] 293. Flip Game
You are playing the following Flip Game with your friend: Given a string that contains only these tw ...
- HashMap相关知识
HashMap的工作原理是近年来常见的Java面试题.几乎每个Java程序员都知道HashMap,都知道哪里要用HashMap,知道Hashtable和HashMap之间的区别,那么为何这道面试题如此 ...
- tarjan通俗易懂题
洛谷2661 https://www.luogu.org/problemnew/show/P2661 分析:求缩点后成环中,环大小最小的size #include<bits/stdc++.h&g ...
- Iterator迭代器解决[为何禁止在foreach内增删]
迭代器的应用场景: 1.对集合进行增加删除,禁止使用foreach,循环的动态操作2.倒序遍历3.遍历循环 步入正题:为何禁止在foreach内进行增删? 先看一下代码: /** * ...
- ABB机器人故障处理指南
ABB工业机器人常见故障处理 1. 开机示教器显示如下 1) 如果机器人开机,示教器一直显示connecting to the robot controller,如上图(robotware版本是白 ...
- python面向对象小tips
(一).python鸭子类型 python作为动态语言继承和多态与静态语言(像java)有很大的不同:比如说在java中的某个方法,如果传入的参数是Animal类型,那么传入的对象必须是Animal类 ...
- 类加载器ClassLoader的理解
最近在做一个热加载Class的小组件,这个组件需要对类加载器ClassLoader有所了解,我就顺便借这个机会把学到的一点皮毛与大家分享一下. 从Class文件开始 ClassLoader,顾名思义就 ...