Использование Ipset и Iptables для фильтрации MAC-адресов

Я использую фильтрацию MAC-адресов на моем маршрутизаторе Linux. Вот что я сделал:

iptables -A INPUT -i eth5 -m mac --mac-source 00:07:e9:84:2b:99 -j RETURN #User: Someuser
iptables -A INPUT -i eth5 -j DROP

Но список правил Iptables огромен - более 400 записей. Недавно я прочитал о преимуществах использования Ipset с Iptables здесь. Но нигде я не нашел никаких советов о том, как сделать то же самое с фильтрацией MAC. Итак, как я могу использовать Ipset для фильтрации MAC-адресов, чтобы уменьшить размер таблицы правил Iptables.

1 ответ

По сути, что-то вроде этого, но вы должны связать IP с MAC, чистых наборов MAC, кажется, не существует:

# ipset --create test macipmap --network 10.0.0.0/16
# ipset --add test 10.0.0.1,00:11:22:33:44:55
# iptables -A INPUT -i eth5 -m set --match-set test src -j ACCEPT

Здесь вы видите содержимое карты и счетчик ссылок, указывающий правило iptables, ссылающееся на этот набор:

# ipset -L test
Name: test
Type: macipmap
References: 1
Header: from: 10.0.0.0 to: 10.0.255.255
Members:
10.0.0.1,00:11:22:33:44:55

Есть несколько вещей для рассмотрения:

  • Этот тип набора технически ограничен до 64 тыс. Последовательных адресов (не уверен, что они должны быть "выровнены по подсети").
  • Ваше ядро ​​должно поддерживать ipset, к сожалению, большинство распространенных стандартных дистрибутивов не
  • Вы можете установить статический ARP в качестве альтернативы
  • MAC-адреса могут быть легко подделаны
Другие вопросы по тегам