Filtragem de entrada no controle de tráfego do Linux: Redirecionar o tráfego para o dispositivo IFB

2

Eu tenho um roteador openwrt e quero moldar o tráfego de entrada para classificar todo o tráfego endereçado a um determinado endereço IP em minha rede doméstica como prioridade baixa. Para isso, quero redirecionar todo o tráfego de entrada para a interface eth1, aquela conectada ao modem DSL, a um dispositivo IFB onde farei a modelagem. Estes são os detalhes do meu sistema:

Linux OpenWrt 2.6.32.27 #7 Fri Jul 15 02:43:34 CEST 2011 mips GNU/Linux

Aqui está o script que estou usando onde a última instrução está falhando:

# Variable definition
ETH=eth1
IFB=ifb1
IP_LP="192.168.1.22/32"
DL_RATE="900kbps"
HP_RATE="890kbps"
LP_RATE="10kbps"
TC="tc"

# Configuring the ifbX interface
insmod ifb
insmod sch_htb
insmod sch_ingress
ifconfig $IFB up

# Adding the HTB scheduler to the ingress interface
$TC qdisc add dev $IFB root handle 1: htb default 11

# Set the maximum bandwidth that each priority class can get, and the maximum borrowing they can do
$TC class add dev $IFB parent 1:1 classid 1:10 htb rate $LP_RATE ceil $DL_RATE
$TC class add dev $IFB parent 1:1 classid 1:11 htb rate $HP_RATE ceil $DL_RATE

# Redirect all ingress traffic arriving at $ETH to $IFB
$TC qdisc del dev $ETH ingress 2>/dev/null
$TC qdisc add dev $ETH ingress
$TC filter add dev $ETH parent ffff: protocol ip prio 1 u32 \
   match u32 0 0 flowid 1:1 \
   action mirred egress redirect dev $IFB

A última instrução falha com:

Action 4 device ifb1 ifindex 9
RTNETLINK answers: No such file or directory
We have an error talking to the kernel

Alguém sabe o que estou fazendo errado?

    
por Dani Camps 26.02.2012 / 12:44

1 resposta

0

Experimente flowid 1:10 ou flowid 1:11 . O ponto de filtragem é escolher para qual classe enviar o pacote, então não envie para o pai!

    
por 09.06.2013 / 06:12