труба в трубе?
- From
- Sergey Zabolotny (2:469/122.1)
- To
- Eugene Grosbein
- Date
- 2006-11-21T20:32:54Z
- Area
- RU.UNIX.BSD
Hello *Eugene.*
Tuesday 21 November 2006 11:57, Eugene Grosbein wrote to Sergey Zabolotny:
SZ>> есть исходящий канал пропускной способностью 1мбит. Эта скорость
SZ>> гарантируется
SZ>> при доступе к локальным ресурсам города. Внутри этого 1мбита есть
SZ>> канал пропускной способностью 512к в мир. Если загрузить канал
SZ>> локальным траффиком наблюдаю тормоза при попытках открыть внешний
SZ>> ресурс. Хочу настроить шейпер таким образом, чтоб при загрузке
SZ>> канала локальным траффиком не зажимался канал в мир.
EG> Надо просто четко сформулировать для себя, как должна поступать
EG> система в краевых условиях. Когда идет максимальная загрузка
EG> одновременно по внешнему и локальному трафику, у тебя канал
EG> должен поделиться поровну, 512K в мир и остаток в 512K в локалку
EG> города? Ну тогда и делай две очереди с одинаковыми весами и без
EG> ограничения скорости и загоняй их в одну трубу с шириной в 1024K.
EG> Когда для обоих потоков хватает канала, все будет работать без
EG> шейпинга (1024+0, 0+1024, 100+900, 900+100 и т.п.). Если возникнет
1024+0 - такое возможно. 512+512 - реально. 0+1024 - нерельно. если считать,
что первое слагаемое локальный траффик. внешний канал ограничен значением 512к
у провайдера. в ситуации когда локальным траффиком канал не забит, но забит
внешним (который мы никак не ограничиваем т.к. его пропускная способность ниже
1мбита, указанного в настройках трубы) получится, что пользователь поставивший
закачку из мира в 10 потоков заставит остальных пользователей сети, желающих
воспользоваться внешним каналом, нервно курить и ждать когда же этот злобный
качальщих освободит канал... это я к тому, что ширину внешнего канала надо
указать явно, но вот как это все скрестить с локальным траффиком - непонятно.
плюс ко всему вышесказанному хотелось бы еще, чтоб пропускные способности и
локального и внешнего канала дробились динамически в зависимости от колличества
пользователей, использующих эти каналы.
EG> конкуренция (суммарный поток более 1024K), очереди в трубе будут
EG> получать каждая не более половины канала.
SZ>> ос: FreeBSD 4.11 + ipfw + dummynet + список сетей считающихся
SZ>> локальными.
EG> Все будет работать.
пока сделано так:
`ipfw pipe 30 config bw 512k queue 30`;
`ipfw queue 30 config pipe 30 weight 50 queue 100 mask src-ip 0xffffffff gred
0.002/10/30/0.1`;
`ipfw -q add 50020 queue 30 ip from 192.168.15.0/24 to not "table(1)" in`;
`ipfw pipe 40 config bw 512k queue 30`;
`ipfw queue 40 config pipe 40 weight 50 queue 100 mask src-ip 0xffffffff gred
0.002/10/30/0.1`;
`ipfw -q add 50030 queue 40 ip from 192.168.15.0/24 to "table(1)" in`;
--- GoldED+ 1.1.5-040321 (WinNT 5.1.2600-Service_Pack_2 i686)
* Origin: [icq:122018120] [mailto:zabolotny[at]hotbox.ru] (2:469/122.1)
SEEN-BY: 50/12 400/814 450/159 1024 461/43 132 640 469/15 38 75 83 122 150 192
SEEN-BY: 469/335 999 4616/3 4625/8 4641/444 5000/76 5000 5006/1 5007/1 5010/70
SEEN-BY: 5011/13 5012/46 5015/28 5019/31 5020/18 175 194 400 545 982 1057 1909
SEEN-BY: 5020/1922 2238 2395 2871 4441 5021/29 5025/3 5026/14 45 5027/12
SEEN-BY: 5030/1080 1957 5034/10 13 5035/3 38 5036/1 5045/7 5049/1 5051/15
SEEN-BY: 5054/1 4 8 9 11 28 35 36 37 45 63 66 67 70 75 84 85 5059/9 5060/88
SEEN-BY: 5061/15 5062/10 5063/3 5064/7 5066/18 5075/5 5076/1 5077/70 5080/1003
SEEN-BY: 5084/9 5085/13 5095/20 5096/18 6001/10
PATH: 469/122 150 5020/400 545 5054/1 37