[GTER] QoS com HTB
Bruno Luchin
bruno at redenetworks.com.br
Wed Nov 23 09:14:07 -02 2005
Boa tarde a todos
Sou novato na lista e estou com o seguinte problema, ao executar o script
abaixo do para HTB ele me retorna a seguinte mensagem ( RTNETLINK answers:
No such file or directory ) outra questão, o autor do script informa que
devem estar presentes os seguintes arquivos ( sch_htb.o, sch_sfq.o e
cls_u32.o ) no diretório
(/lib/modules/2.6.11-72032U10_21cl/kernel/net/sched ). Tenho todos os
arquivos porém todos estão com as extensões .ko, por exemplo sch_htb.ko e
assim por diante, já tentei renomiar os arquivos (.ko) para (.o) porém
atmbém não funcionou.
Também fiz o download e instalação do pacote iproute2
para poder utilizar a ferramenta tc em sua versão mais atual, também fiz o
download do arquivo htb3.6-020525.tgz no repositório
http://luxik.cdi.cz/~devik/qos/htb/v3/htb3.6-020525.tgz , que segundo o
autor do tutorial nesse pacote existe uma versão do tc compilada para uso
com o HTB. Por favor se alguém que conhece a ferramenta e puder me ajudar,
já tentei todos os tutoriais e scripts disponíveis mas infelizmente nada
funcionou. Estou utilizando um Conectiva Linux versão 10 Agradeço desde já a
atenção!!
Agradeço desde já a atenção
Bruno Luchin
Segue o script
#!/bin/bash
tc qdisc del dev eth0 root
# Remove qualquer qdisc associado a interface eth0.
tc qdisc add dev eth0 root handle 1: htb default 50
# Associa uma regra de enfileiramento (qdisc) HTB a interface eth0 e vincula
a
# esta o manipulador "1:". Este manipulador será referenciado por comandos
# abaixo para ajudar a criar a estrutura hierárquica. O "default 50" diz que
# todo tráfego que não estiver associado a uma classe específica será feito
# pela classe 50.
tc class add dev eth0 parent 1: classid 1:1 htb rate 512kbit
# Cria uma classe htb raiz identificando-a como "1:1" abaixo do qdisc "1:"
com
# a taxa de 512kbit/s.
tc class add dev eth0 parent 1:1 classid 1:10 htb rate 272kbit ceil 512kbit
tc class add dev eth0 parent 1:1 classid 1:20 htb rate 128kbit ceil 512kbit
tc class add dev eth0 parent 1:1 classid 1:30 htb rate 64kbit ceil 512kbit
tc class add dev eth0 parent 1:1 classid 1:40 htb rate 32kbit ceil 512kbit
tc class add dev eth0 parent 1:1 classid 1:50 htb rate 16kbit ceil 512kbit
# Cria cinco classes filhas da classe raiz "1:1" identificando-as como
"1:10",
# "1:20", "1:30", "1:40" e "1:50" e atribui a elas as taxas de 272kbit/s,
# 128kbit/s, 64kbit/s, 32kbit/s e 16kbit/s respectivamente. Instrui ao HTB
que
# o tráfego de qualquer uma das classes poderá chegar ao limite de 512kbit/s
# (ceil). Se ceil não for especificado ele será igual a taxa (rate).
tc qdisc add dev eth0 parent 1:10 handle 10: sfq perturb 10
tc qdisc add dev eth0 parent 1:20 handle 20: sfq perturb 10
tc qdisc add dev eth0 parent 1:30 handle 30: sfq perturb 10
tc qdisc add dev eth0 parent 1:40 handle 40: sfq perturb 10
tc qdisc add dev eth0 parent 1:50 handle 50: sfq perturb 10
# Cria manipuladores sfq "10:" a "50:" sob as classes "1:10" a "1:50". O
qdisc
# sfq objetiva fornecer uma distribuição justa entre os diversos tráfegos de
# uma mesma classe, fazendo com que as várias conexões sob uma mesma classe
# dividam de forma equilibrada entre si. O uso deste qdisc evita que uma
# conexão de uma classe "roube" os recursos das demais na mesma classe. O
# parâmetro "perturb 10" é o tempo em segundos onde será verificado a
# solicitação de uso de banda por conexão.
U32="tc filter add dev eth0 parent 1:0 protocol ip prio 1 u32 "
U32=$U32"match ip src 192.168.0.0/24 match ip dst 192.168.1.0/24"
# A variável "U32" foi criada para tornar as linhas de comando a seguir mais
# curtas. O filtro u32 é aplicado para indentificar endereços ip e/ou portas
# tcp/udp. O parâmetro prio diz qual é prioridade que os pacotes terão. Este
# parâmetro varia de 0 a 15. Quanto menor o valor de prio maior a
prioridade.
$U32 match ip sport 22 0xffff flowid 1:10
$U32 match ip sport 8800 0xffff flowid 1:10
$U32 match ip sport 8080 0xffff flowid 1:20
$U32 match ip sport 8008 0xffff flowid 1:30
$U32 match ip sport 8000 0xffff flowid 1:40
# Define como o tráfego será direcionado para cada classe com base nos
# endereços e portas de origem e endereços de destino através dos parâmetros
# src, sport e dst respectivamente. A associação destes com suas classes é
# estabelecida através do parâmetro flowid. Lembre-se que todo tráfego não
# incluso em um destes filtros será através da classe 50. O número
hexadecimal
# após a porta pode ser utilizado para identificar uma faixa de portas
# consecutivas. Para referenciar uma única porta coloque sempre "0xffff"
www.redenetworks.com.br
Bruno Luchin
Departamento de Tecnologia
Rede Networks
<mailto:bruno at redenetworks.com.br> bruno at redenetworks.com.br
tel:
(43) 3027-4450
<https://www.plaxo.com/add_me?u=547892&v0=1090107&k0=805252964> Add me to
your address book...
<http://www.plaxo.com/signature> Want a signature like this?
More information about the gter
mailing list