Hi,
I wanted to configure the following :
1. VPN + some other special connections (TCP 82,8282,23,22 and ICMP) to
have priority over the rest
2. special upstream for our updating system on port 4000
3. within the VPN tunnels citrix traffic ( TCP 1494, 2598) + icmp has
priority
I need this for both incoming and outgoing traffic as it is the bandwith
managment config on a central system from which 5 vpn tunnels are
configured to small offices and for which also mail , surf ,...
traffic exists.
I started from a working config file implementing 1. and 2.
As I understood it is possible to make a distinction within a class for
different subclasses thus allowing me to implement 3. . Therefore I
added the lines with ''===>>'' .
I clearly did something wrong cause it doesn''t compile :( Can anyone
explain me how to implement 3. ?
kind regards,
Pieter
$intDev = "adsl0";
// in bps (bits per second)
$maxUpstream = 2048000;
$maxDownstream = 2048000;
// Internet device
dev $intDev {
// outgoing traffic
egress {
/* classification */
// very interactive
class (<$group1>)
//VPN Protocols
if ip_proto == 50
if ip_proto == 47
// Known very interactive
if tcp_dport == 23
// Our interactive sessions
if tcp_dport == 82
if tcp_dport == 8282
// voorlopig omdat ''combined'' spullen precies niet
meer werken
// op kernel 2.4.24-axs-1
if tcp_dport == 22 && ip_tos_delay == 1
// ICMP
if ip_proto == 1;
// update server
class (<$group2>)
if tcp_sport == 4000;
// default
class (<$rest>)
if 1;
/* Queueing */
htb ( ) {
/* rate is what they normally get, ceil is the maximum they
can get when borrowing from the parent */
/* this is the surrounding class. limit the upstream here to
something just below the
real limit. this is to avoid that the next device (maybe
cable modem), will queue which will
result in having us no control ... */
class ( rate $maxUpstream bps, ceil $maxUpstream bps,
quantum 1 sec) {
$group1 = class ( rate ($maxUpstream / 8
*3) bps, ceil ($maxUpstream / 4) bps ){
==========>> // special citrix applications
==========>> class (<$vpn_prior>)
==========>> if tcp_dport == 1494
==========>> if tcp_dport == 2598
==========>> if ip_proto == 1;
==========>> // default
==========>> class (<$rest>)
==========>> if 1;
==========>> /* Queueing */
==========>> htb ( ) {
==========>> $vpn_prior = class (
rate ($maxUpstream / 8 *3) bps, ceil ($maxUpstream / 4) bps );
==========>> $rest = class ( rate
($maxUpstream / 8) bps, ceil ($maxUpstream / 4) bps ) ;
==========>> }
==========>> }
$group2 = class ( rate ($maxUpstream /
2) bps, ceil ($maxUpstream / 8 * 7) bps ) ;
$rest = class ( rate ($maxUpstream / 8)
bps, ceil ($maxUpstream / 4) bps ) ;
}
}
}
// incoming traffic
ingress {
// speeds
$veryhigh_cir = $maxDownstream / 4;
$veryhigh_pir = $maxDownstream / 4 * 3;
$low_cir = $maxDownstream / 4;
$low_pir = $maxDownstream / 4;
// variables to make categories
$is_veryhigh = (tcp_sport == PORT_SSH && ip_tos_delay == 1)
|| (ip_proto == 50) || (ip_proto == 47);
$is_low = 1;
// Double Leaky Buckets
$is_veryhigh_pol = DLB(cir $veryhigh_cir bps,cbs 20kB,pir
$veryhigh_pir bps,pbs 5kB) {
==========>> class (<$vpn_prior>)
==========>> if tcp_dport == 1494
==========>> if tcp_dport == 2598
==========>> if ip_proto == 1;
==========>> // default
==========>> class (<$rest>)
==========>> if 1;
==========>> prio {
==========>> $vpn_prior= class {}
==========>> $rest = class {}
==========>>
==========>> }
==========>> };
$is_low_pol = DLB(cir $low_cir bps,cbs 20kB,pir $low_pir
bps,pbs 5kB);
// do the policing
class (<>)
if $is_veryhigh && DLB_else_drop($is_veryhigh_pol);
class (<>)
if $is_low && DLB_else_drop($is_low_pol);
}
}
--
**********************************************
NEW ADDRESS as of 20/12/2004:
Dellingstraat 28b
2800 Mechelen
**********************************************
aXs GUARD has completed security and anti-virus checks on this e-mail
(http://www.axsguard.com)
_______________________________________________
LARTC mailing list / LARTC@mailman.ds9a.nl
http://mailman.ds9a.nl/mailman/listinfo/lartc HOWTO: http://lartc.org/