Blame examples/README.cbq

Packit d3f73b
# CHANGES
Packit d3f73b
# -------
Packit d3f73b
# v0.3a2- fixed bug in "if" operator. Thanks kad@dgtu.donetsk.ua.
Packit d3f73b
# v0.3a-  added TIME parameter. Example:
Packit d3f73b
#         TIME=00:00-19:00;64Kbit/6Kbit
Packit d3f73b
#         So, between 00:00 and 19:00 RATE will be 64Kbit.
Packit d3f73b
#         Just start "cbq.init timecheck" periodically from cron (every 10
Packit d3f73b
#         minutes for example).
Packit d3f73b
#         !!! Anyway you MUST start "cbq.init start" for CBQ initialize.
Packit d3f73b
# v0.2 -  Some cosmetique changes. Now it more compatible with
Packit d3f73b
#         old bash version. Thanks to Stanislav V. Voronyi
Packit d3f73b
#         <stas@cnti.uanet.kharkov.ua>.
Packit d3f73b
# v0.1 -  First public release
Packit d3f73b
# 
Packit d3f73b
# README
Packit d3f73b
# ------
Packit d3f73b
# 
Packit d3f73b
# First of all - this is just a SIMPLE EXAMPLE of CBQ power.
Packit d3f73b
# Don't ask me "why" and "how" :)
Packit d3f73b
# 
Packit d3f73b
# This is an example of using CBQ (Class Based Queueing) and policy-based
Packit d3f73b
# filter for building smart ethernet shapers. All CBQ parameters are
Packit d3f73b
# correct only for ETHERNET (eth0,1,2..) linux interfaces. It works for
Packit d3f73b
# ARCNET too (just set bandwidth parameter to 2Mbit). It was tested
Packit d3f73b
# on 2.1.125-2.1.129 linux kernels (KSI linux, Nostromo version) and 
Packit d3f73b
# ip-route utility by A.Kuznetsov (iproute2-ss981101 version). 
Packit d3f73b
# You can download ip-route from ftp://ftp.inr.ac.ru/ip-routing or
Packit d3f73b
# get iproute2*.rpm (compiled with glibc) from ftp.ksi-linux.com.
Packit d3f73b
# 
Packit d3f73b
# 
Packit d3f73b
# HOW IT WORKS
Packit d3f73b
# 
Packit d3f73b
# Each shaper must be described by config file in $CBQ_PATH
Packit d3f73b
# (/etc/sysconfig/cbq/) directory - one config file for each CBQ shaper.
Packit d3f73b
# 
Packit d3f73b
# Some words about config file name:
Packit d3f73b
# Each shaper has its personal ID - two byte HEX number. Really ID is 
Packit d3f73b
# CBQ class.
Packit d3f73b
# So, filename looks like:
Packit d3f73b
# 
Packit d3f73b
# cbq-1280.My_first_shaper
Packit d3f73b
# ^^^ ^^^  ^^^^^^^^^^^^^
Packit d3f73b
#  |  |            |______ Shaper name - any word
Packit d3f73b
#  |  |___________________ ID (0000-FFFF), let ID looks like shaper's rate
Packit d3f73b
#  |______________________ Filename must begin from "cbq-" 
Packit d3f73b
# 
Packit d3f73b
# 
Packit d3f73b
# Config file describes shaper parameters and source[destination] 
Packit d3f73b
# address[port].
Packit d3f73b
# For example let's prepare /etc/sysconfig/cbq/cbq-1280.My_first_shaper:
Packit d3f73b
# 
Packit d3f73b
# ----------8<---------------------
Packit d3f73b
# DEVICE=eth0,10Mbit,1Mbit
Packit d3f73b
# RATE=128Kbit
Packit d3f73b
# WEIGHT=10Kbit
Packit d3f73b
# PRIO=5
Packit d3f73b
# RULE=192.168.1.0/24
Packit d3f73b
# ----------8<---------------------
Packit d3f73b
# 
Packit d3f73b
# This is minimal configuration, where:
Packit d3f73b
# DEVICE:  eth0   - device where we do control our traffic
Packit d3f73b
#          10Mbit - REAL ethernet card bandwidth
Packit d3f73b
#          1Mbit  - "weight" of :1 class (parent for all shapers for eth0),
Packit d3f73b
#                   as a rule of thumb weight=batdwidth/10.
Packit d3f73b
#          100Mbit adapter's example: DEVICE=eth0,100Mbit,10Mbit
Packit d3f73b
#          *** If you want to build more than one shaper per device it's
Packit d3f73b
#              enough to describe bandwidth and weight once  - cbq.init
Packit d3f73b
#              is smart :) You can put only 'DEVICE=eth0' into cbq-* 
Packit d3f73b
#              config file for eth0.
Packit d3f73b
# 
Packit d3f73b
# RATE:    Shaper's speed - Kbit,Mbit or bps (bytes per second)
Packit d3f73b
# 
Packit d3f73b
# WEIGHT:  "weight" of shaper (CBQ class). Like for DEVICE - approx. RATE/10
Packit d3f73b
# 
Packit d3f73b
# PRIO:    shaper's priority from 1 to 8 where 1 is the highest one.
Packit d3f73b
#          I do always use "5" for all my shapers.
Packit d3f73b
# 
Packit d3f73b
# RULE:    [source addr][:source port],[dest addr][:dest port]
Packit d3f73b
#          Some examples:
Packit d3f73b
# RULE=10.1.1.0/24:80         - all traffic for network 10.1.1.0 to port 80
Packit d3f73b
#                               will be shaped.
Packit d3f73b
# RULE=10.2.2.5               - shaper works only for IP address 10.2.2.5   
Packit d3f73b
# RULE=:25,10.2.2.128/25:5000 - all traffic from any address and port 25 to
Packit d3f73b
#                               address 10.2.2.128 - 10.2.2.255 and port 5000
Packit d3f73b
#                               will be shaped.
Packit d3f73b
# RULE=10.5.5.5:80,           - shaper active only for traffic from port 80 of
Packit d3f73b
#                               address 10.5.5.5
Packit d3f73b
# Multiple RULE fields per one config file are allowed. For example:
Packit d3f73b
# RULE=10.1.1.2:80
Packit d3f73b
# RULE=10.1.1.2:25
Packit d3f73b
# RULE=10.1.1.2:110
Packit d3f73b
# 
Packit d3f73b
# *** ATTENTION!!!
Packit d3f73b
# All shapers do work only for outgoing traffic!
Packit d3f73b
# So, if you want to build bidirectional shaper you must set it up for
Packit d3f73b
# both ethernet card. For example let's build shaper for our linux box like:
Packit d3f73b
# 
Packit d3f73b
#                     ---------             192.168.1.1
Packit d3f73b
# BACKBONE -----eth0-|  linux  |-eth1------*[our client]
Packit d3f73b
#                     ---------
Packit d3f73b
# 
Packit d3f73b
# Let all traffic from backbone to client will be shaped at 28Kbit and
Packit d3f73b
# traffic from client to backbone - at 128Kbit. We need two config files:
Packit d3f73b
# 
Packit d3f73b
# ---8<-----/etc/sysconfig/cbq/cbq-28.client-out----
Packit d3f73b
# DEVICE=eth1,10Mbit,1Mbit
Packit d3f73b
# RATE=28Kbit
Packit d3f73b
# WEIGHT=2Kbit
Packit d3f73b
# PRIO=5
Packit d3f73b
# RULE=192.168.1.1
Packit d3f73b
# ---8<---------------------------------------------
Packit d3f73b
# 
Packit d3f73b
# ---8<-----/etc/sysconfig/cbq/cbq-128.client-in----
Packit d3f73b
# DEVICE=eth0,10Mbit,1Mbit
Packit d3f73b
# RATE=128Kbit
Packit d3f73b
# WEIGHT=10Kbit
Packit d3f73b
# PRIO=5
Packit d3f73b
# RULE=192.168.1.1,
Packit d3f73b
# ---8<---------------------------------------------
Packit d3f73b
#                 ^pay attention to "," - this is source address!
Packit d3f73b
# 
Packit d3f73b
# Enjoy.