12345678910111213141516171819202122232425262728293031323334353637383940 |
- Network classifier cgroup
- -------------------------
- The Network classifier cgroup provides an interface to
- tag network packets with a class identifier (classid).
- The Traffic Controller (tc) can be used to assign
- different priorities to packets from different cgroups.
- Also, Netfilter (iptables) can use this tag to perform
- actions on such packets.
- Creating a net_cls cgroups instance creates a net_cls.classid file.
- This net_cls.classid value is initialized to 0.
- You can write hexadecimal values to net_cls.classid; the format for these
- values is 0xAAAABBBB; AAAA is the major handle number and BBBB
- is the minor handle number.
- Reading net_cls.classid yields a decimal result.
- Example:
- mkdir /sys/fs/cgroup/net_cls
- mount -t cgroup -onet_cls net_cls /sys/fs/cgroup/net_cls
- mkdir /sys/fs/cgroup/net_cls/0
- echo 0x100001 > /sys/fs/cgroup/net_cls/0/net_cls.classid
- - setting a 10:1 handle.
- cat /sys/fs/cgroup/net_cls/0/net_cls.classid
- 1048577
- configuring tc:
- tc qdisc add dev eth0 root handle 10: htb
- tc class add dev eth0 parent 10: classid 10:1 htb rate 40mbit
- - creating traffic class 10:1
- tc filter add dev eth0 parent 10: protocol ip prio 10 handle 1: cgroup
- configuring iptables, basic example:
- iptables -A OUTPUT -m cgroup ! --cgroup 0x100001 -j DROP
|