cgroup子系统net_cls 能够给 packet 打上 classid 的标签,用于过滤分类,这个classid就是用于标记skb
所属的 qdisc class 的。有了这个标签,流量控制器(tc)能够对不一样的 cgroup 的 packet 起做用,Netfilter(iptables)也能够基于这个标签有对应的动做。建立一个 net_cls cgroup 对应的是建立一个 net_cls.classid 文件,这个文件初始化为 0。能够写 16 进制的 0xAAAABBBB 到这个文件里面,AAAA 是 major 号,BBBB 是 minor 号。读这个文件返回的是十进制的数字。python
以下,建立两个cgroup组,每一个组分配不一样的handle号,指定不一样的带宽。ubuntu
root@ubuntu:/sys/fs/cgroup/net_cls# mkdir client
root@ubuntu:/sys/fs/cgroup/net_cls# cd client/ root@ubuntu:/sys/fs/cgroup/net_cls/client# l cgroup.clone_children cgroup.procs net_cls.classid net_prio.ifpriomap net_prio.prioidx notify_on_release tasks root@ubuntu:/sys/fs/cgroup/net_cls/client# echo 0x10010 > net_cls.classid root@ubuntu:/sys/fs/cgroup/net_cls/client# cat net_cls.classid 65552
root@ubuntu:/sys/fs/cgroup/net_cls# mkdir server root@ubuntu:/sys/fs/cgroup/net_cls# cd server/ root@ubuntu:/sys/fs/cgroup/net_cls/server# l cgroup.clone_children cgroup.procs net_cls.classid net_prio.ifpriomap net_prio.prioidx notify_on_release tasks root@ubuntu:/sys/fs/cgroup/net_cls/server# echo 0x10020 > net_cls.classid root@ubuntu:/sys/fs/cgroup/net_cls/server# cat net_cls.classid 65568
接下来配置tc,写入到cgroup的net_cls.classid中的handle号,要与tc配置中的classid号相同工具
tc qdisc add dev ens8 root handle 1:0 htb default 1 tc class add dev ens8 parent 1:0 classid 1:1 htb rate 10000Mbit tc class add dev ens8 parent 1:1 classid 1:10 htb rate 100Mbit ceil 100Mbit tc class add dev ens8 parent 1:1 classid 1:20 htb rate 1000Mbit ceil 1000Mbit
设置过滤器:spa
tc filter add dev ens8 parent 1:1 protocol ip prio 10 handle 1:10 cgroup tc filter add dev ens8 parent 1:1 protocol ip prio 10 handle 1:20 cgroup
接下来使用cgexec工具,来执行对应的程序,咱们能够看到流量控制如咱们的预期:code
cgexec -g net_cls:server python test.py 129.9.123.89 bandwidth 95.9717340903 MB/s cgexec -g net_cls:client python test.py 129.9.123.89 bandwidth 11.3290806068 MB/s
修改带宽命令以下:server
tc class change dev ens8 parent 1:1 classid 1:40 htb rate 512Kbit ceil 512Kbit
原理分析待续blog