Почему ipset преуспевает при добавлении диапазонов ipv4, но не при добавлении диапазона ipv6?
Использование ipset для очистки громоздких наборов правил iptable не кажется таким разным между IPv4 и IPv6:
# ipset create TEST hash:net family inet
# ipset create DEMO hash:net family inet6
# iptables -A INPUT -m set --match-set TEST src -j DROP
# ip6tables -A INPUT -m set --match-set DEMO src -j DROP
Однако после добавления диапазонов IP- адресов непредвиденные ошибки возникают только для диапазонов IPv6:
# ipset add TEST 192.0.2.0-192.0.2.127
# ipset add DEMO 2001:db8::-2001:db8::ffff
ipset v6.34: Syntax error: IP address or IP/cidr must be specified: 2001:db8::-2001:db8::ffff
Это неожиданно, так как кажется, что ipset может анализировать эти адреса IPv6:
# ipset add DEMO 2001:db8::/112
# ipset del DEMO 2001:db8::/112
# ipset add DEMO 2001:db8::ffff/112
# ipset -L DEMO | tail -2
Members:
2001:db8::/112
Почему бы ipset принять fromaddr-toaddr
диапазоны для IPv4, но считают то же самое синтаксической ошибкой для IPv6?
1 ответ
Решение
fromaddr-toaddr
синтаксис поддерживается только для IPv4. использование cidr
запись для добавления диапазонов IPv6.
Для семейства inet можно добавить или удалить несколько записей, указав диапазон или сеть IPv4-адресов в части IP-адреса записи - man 8 ipset