Iptables ipset 使用经验
iptables 加上 ipset,对大批量地屏蔽恶意 ip,非常有用,本文总结一些有用的 ipset 命令。
查看靠前的链:
iptables -L -n | head
白名单
ipset create mw_white hash:ip family inet hashsize 4096 maxelem 131072 -exist
iptables -I INPUT 1 -m set --match-set mw_white src -j ACCEPT
ipset list mw_white
ipset test mw_white 1.2.3.4
ipset add mw_white 1.2.3.4 -exist
ipset del mw_white 1.2.3.4
黑名单
ipset create mw_ban hash:ip family inet hashsize 4096 maxelem 131072 timeout 86400 -exist
iptables -I INPUT 2 -m set --match-set mw_ban src -j DROP
ipset list mw_ban
ipset test mw_ban 1.2.3.4
ipset add mw_ban 1.2.3.4 -exist
ipset add banhash 1.2.3.0/24
ipset del mw_ban 1.2.3.4
速率
活着
要想 ipset 活着,必须保证以下:
- 关机前 ipset 改后的规则已保存
ipset save > /etc/ipset.conf - 关机前 iptables 改后的规则已保存
iptables-save > /etc/iptables/rules.v4 - 开机后 ipset 规则已恢复
ipset restore -exist < /etc/ipset.conf - 开机后 iptables 规则已恢复
iptables-restore -exist < /etc/iptables/rules.v4
自动化
以下脚本未经完全测试,暂勿使用。
自动脚本: 因为 iptables-persistent 只管 iptables,不管 ipset,所以要建一个 ipset 的自动恢复脚本。
# 放进 /etc/systemd/system/ipset-restore.service
[Unit]
Description=Restore IP sets
Before=netfilter-persistent.service
[Service]
Type=oneshot
ExecStart=/usr/sbin/ipset restore
StandardInput=file:/etc/ipset.conf
RemainAfterExit=yes
[Install]
WantedBy=multi-user.target
最后重启服务:
systemctl daemon-reload
systemctl enable ipset-restore