[Firehol-devs] FireQOS... I think I did it!

Tsaousis, Costa costa at tsaousis.gr
Sat Mar 15 15:16:10 GMT 2014


The config I posted had a few typos.
Here is the right one:

--- /etc/firehol/fireqos.conf BEGIN

DEVICE=dsl0
INPUT_SPEED="$((12200 * 85 / 100))kbit"
OUTPUT_SPEED="$((890  * 95 / 100))kbit"
LINKTYPE="adsl local pppoe-llc"

# ------------- COPY & PASTE BELLOW THIS POINT -------------

server_rtp_ports="udp/10000:10100"
server_lol_ports="udp/5000:5500 tcp/8393:8400,2099,5223,5222,8088"
server_openvpn_ports="any/1195:1198"
server_mytorrent_ports="any/51414"

interface $DEVICE world bidirectional $LINKTYPE input rate $INPUT_SPEED
output rate $OUTPUT_SPEED

        class voip commit 100kbit pfifo
                server sip
                client sip
                server rtp
                client stun

        class interactive input commit 20% output commit 10%
                server icmp

                server dns
                client dns

                server ssh
                client ssh

                client teamviewer
                client lol

        class chat input commit 1000kbit output commit 440kbit
                client facetime

                server hangouts
                client hangouts

                client gtalk
                client jabber

        class vpns input commit 20% output commit 10%
                server pptp
                server GRE
                server openvpn

        class servers
                server http

        class surfing prio keep commit 10%
                client surfing
                client rsync

        class synacks
                match tcp syn
                match tcp ack

        class default

        class torrents
                client torrents
                server mytorrent prio 1
                match sports 16384:65535 dports 16384:65535

--- /etc/firehol/fireqos.conf END

A few more notes:

4. input and output can also be given to 'match' statements. FireQOS will
automatically revert the rule (src<->dst, sports<->dports) if the match
statement is input and interface is output and vice versa.

5. when definining bidirectional interfaces, '-in' or '-out' is appended to
the interface name. Thus to get status of interface 'world' input, you have
to write 'fireqos status world-in'.

Costa




On Sat, Mar 15, 2014 at 4:26 PM, Tsaousis, Costa <costa at tsaousis.gr> wrote:

> Hi all,
>
> I think I did it!
>
> FireQOS can now be exactly like FireHOL. server/client statements and full
> bi-directional interfaces.
>
> Check this config:
>
> --- /etc/firehol/fireqos.conf BEGIN
>
> DEVICE=dsl0
> INPUT_SPEED="$((12200 * 85 / 100))kbit"
> OUTPUT_SPEED="$((890  * 95 / 100))kbit"
> LINKTYPE="adsl local pppoe-llc"
>
> server_rtp_ports="udp/10000:10100"
> server_lol_ports="udp/5000:5500 tcp/8393:8400,2099,5223,5222,8088"
> server_openvpn_ports="any/1195:1198"
> server_mytorrent_ports="any/51414"
>
> interface $DEVICE world-in bidirectional $LINKTYPE input rate $INPUT_SPEED
> output rate $OUTPUT_SPEED
>
>         class voip commit 100kbit pfifo
>                 server sip
>                 client sip
>                 server rtp
>                 client stun
>
>         class interactive input commit 20% output commit 10%
>                 server icmp
>
>                 server dns
>                 client dns
>
>                 server ssh
>                 client ssh
>
>                 client teamviewer
>                 client lol
>
>         class chat input commit 1000kbit output commit 440kbit
>                 client facetime
>
>                 server hangouts
>                 client hangouts
>
>                 client gtalk
>                 client jabber
>
>         class vpns input commit 20% output commit 10%
>                 server pptp
>                 server GRE
>                 server openvpn
>
>         class servers
>                 server http
>
>         class surfing prio keep commit 10%
>                 client surfing
>                 client rsync
>
>         class synacks
>                 match tcp syn
>                 match tcp ack
>
>         class default
>
>         class torrents
>                 client torrents
>                 server mytorrent prio 1
>                 match ports 16384:65535
>
> --- /etc/firehol/fireqos.conf END
>
> Notes:
>
> 1. server and client should be given with the INPUT interface in mind.
> FireQOS will automatically invert it for the output interface.
>
> 2. services can be defined much like FireHOL. client ports are not needed
> though. Only server ports are used by FireQOS.
>
> 3. there are two special keywords in interfaces and classes: input and
> output. These are used to specify interface and class rates (commit, max,
> etc) for each direction. If no input or output is given the rates are
> applied in both directions.
>
> I just committed it to github.
>
> At last... a traffic shaper for humans!
>
> Enjoy...
>
> Costa
>
>
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.firehol.org/pipermail/firehol-devs/attachments/20140315/81d566f5/attachment-0002.html>


More information about the Firehol-devs mailing list