DHCP и привязка к порту коммутатора
- From
- Eugene Grosbein (2:5006/1)
- To
- All (2:5054/37.63)
- Date
- 2006-09-15T10:39Z
- Area
- RU.UNIX.BSD
Reply-To: eugen@grosbein.pp.ru
Привет!
Есть микробиллинг под FreeBSD для маленькой локалки, считающий трафик
на IP-адресах счетчиками ipfw count. Использовался в условиях, где можно было
полагаться на неизменность MAC-адреса рабочих станций, staticarp
на интерфейсе роутера и вперед.
Нужно перенести его немножко в другие условия. MAC-адреса меняются
произвольно, IP-адреса будут выдаваться по DHCP. Можно полагаться
на неизменность порта коммутатора, в который включается рабочая станция,
то есть нужно в итоге считать трафик "на порту свича". Свичи L2 управляемые,
но по SNMP счетчики c интерфейсов снимать не годится, считать надо
трафик на L3, а не L2.
Как лучше привязать выдачу IP к номеру порта?
Можно попробовать найти недорогой свич, отсылающий SNTP trap при появлении
нового MAC-а на порту, ловить этот трап на роутере и вести на нем
таблицу соответствия MAC-ов и портов свича, а потом при запросе к DHCP
можно как-то заставить демон выдать определенный IP для нового MAC-а?
Или в крайнем случае пусть выдает любой свободный, еще одно соответствие
MAC-IP наверое можно обработать.
Можно при запросе к DHCP опрашивать свич, выясняя соотвествие MAC-порт
и корректировать таблицу IP-порт на роутере. Можно совмещать трапы
и опрос (трап может и пропасть).
А может, есть более правильные пути?
Eugene
--- slrn/0.9.8.0 (FreeBSD)
* Origin: Svyaz Service JSC (2:5006/1@fidonet)
SEEN-BY: 50/12 203 400/814 450/159 186 1024 451/30 461/43 132 640 469/999
SEEN-BY: 550/196 4616/3 4625/8 4635/4 4641/444 5000/76 5000 5006/1 8 9 10 14
SEEN-BY: 5006/15 16 17 5007/1 5010/70 352 5011/13 5012/46 5015/28 5019/31
SEEN-BY: 5020/18 154 175 194 400 545 549 715 758 982 1057 1523 1604 1630 1909
SEEN-BY: 5020/1922 2142 2238 2395 2450 2590 2871 4441 5021/3 29 5022/128
SEEN-BY: 5025/3 750 5026/45 5027/12 5029/32 5030/49 500 556 966 1063 1080 1900
SEEN-BY: 5030/1957 2828 5031/47 70 5034/10 13 5035/3 38 5036/1 5040/47 5042/13
SEEN-BY: 5045/7 5049/1 50 97 5051/15 5054/1 4 8 9 11 28 35 36 37 45 63 66 67
SEEN-BY: 5054/70 75 84 85 5055/95 5057/1 5059/9 5060/88 5061/15 5062/1 10
SEEN-BY: 5063/3 5064/7 5066/18 5074/9 5075/5 5077/70 5080/80 1003 5082/6
SEEN-BY: 5083/21 5085/13 5090/108 5094/4 5095/20 5096/18 5099/11 6001/3 10
PATH: 5006/1 5020/400 4441 545 5054/1 37