Skip to content

hkbakke/tc-gen

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

34 Commits
 
 
 
 
 
 

Repository files navigation

tc-gen

tc-gen is a wrapper around all the complexity of modern traffic shaping and policing on linux. It tries to use best practices whenever possible while still being generic and easy to use. The script is using HTB with fq_codel to do the heavy lifting.

Run tc-gen without parameters to see more details.

Examples of common use

Shape egress to 25 mbit/s

tc-gen -i eth0 -u 25

Shape egress to 5 mbit/s and ingress to 10 mbit/s using IFB-interface

tc-gen -i eth0 -u 5 -d 10 -f ifb0

Shape egress to 1500 kbit/s and police ingress to 20 mbit/s

tc-gen -i eth0 -u 1500k -d 20M

Display current configuration

tc-gen -i eth0

Remove configuration

tc-gen -i eth0 -x

/etc/network/interfaces examples

# Simple DHCP WAN config
allow-auto eth1
iface eth1 inet dhcp
    up /usr/local/bin/tc-gen -i ${IFACE} -u 10 -d 100 -f ifb0

# More advanced example with an additional tc filter exclude for
# UDP-encapsulated IPsec ESP-traffic to avoid double counting IPsec data on
# ingress
allow-auto bond0.12
iface bond0.12 inet dhcp
    up /usr/local/bin/tc-gen -i ${IFACE} -u 10 -d 100 -f ifb0

# Add additional rules to the post-commands file (location can be overridden by -p)
echo '${TC} filter add dev ${IF_NAME} parent ffff: protocol ip prio 1 u32 match ip protocol 17 0xff match ip dport 4500 0xffff action pass' >> /etc/tc-gen/post-commands

# Example with egress shaping on gre-tunnel
allow-auto gre2
iface gre2 inet tunnel
    address 10.0.1.0
    netmask 255.255.255.254
    local 10.0.2.2
    endpoint 10.1.2.2
    mode gre
    mtu 1400
    up /usr/local/bin/tc-gen -i ${IFACE} -u 25