iptables 规则设定未生效

最近需要管理一台实体主机,上面还有跑不少服务,得为其设置防火墙。

因为主机是 Ubuntu,第一反应考虑使用 ufw。

ufw 设定规则如下:

ufw allow ssh
ufw allow http
ufw allow 8006 
ufw deny 3306

我期望的结果:allow 端口允许访问,deny端口禁止访问。
实际结果:80063306 都可以访问。

iptables 设定规则如下:

iptables -I INPUT -p tcp --dport ssh -j ACCEPT
iptables -I INPUT -p tcp --dport http -j ACCEPT
iptables -I INPUT -p tcp --dport 8006 -j ACCEPT
iptables -I INPUT -p icmp -j ACCEPT
iptables -I INPUT -i lo -j ACCEPT
iptables -I INPUT -m state --state ESTABLISHED,RELATED -j ACCEPT

iptables -A INPUT -j REJECT
iptables -A FORWARD -j REJECT

我期望的结果:除了指定允许端口外,其他端口全部禁止。
实际结果:未允许的端口确实不能连接,但指定允许的 8006也不能访问了。

前后使用两种方式都没能达到我想要的效果,请问:上述规则是哪里存在问题,导致与预期不符?

阅读 3.6k
撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题