举些例子,自己学习

  iptables 使用时的样板

  在设定 iptables 的封包过滤规则时,有几个样板的动作,若先熟悉他们,往后就可自行套用,依此类推,很快地,您就能够进入这个天地之中。

  观察现在的设定

  作法如下∶

  iptables -L -n

  iptablse -t nat -L -n

  定义变数

  FW_IP="163.26.197.8"

  打开核心 forward 功能

  作法如下∶

  ###-----------------------------------------------------###

  # 打开 forward 功能

  ###-----------------------------------------------------###

  echo "1" > /proc/sys/net/ipv4/ip_forward

  清除任何的规则

  一开始要先清除任何的规则,重新开始,以免旧有的规则影响新的设定。作法如下∶

  ###-----------------------------------------------------###

  # 清除先前的设定

  ###-----------------------------------------------------###

  # 清除预设表 filter 中,任何规则链中的规则

  iptables -F

  # 清除预设表 filter 中,使用者自订链中的规则

  iptables -X

  # 清除mangle表中,任何规则链中的规则

  iptables -F -t mangle

  # 清除mangle表中,使用者自订链中的规则

  iptables -t mangle -X

  # 清除nat表中,任何规则链中的规则

  iptables -F -t nat

  # 清除nat表中,使用者自订链中的规则

  iptables -t nat -X

  选定预设的政策

  接着,要选定各个不同的规则链,预设的政策为何。作法如下∶

  预设全部丢弃∶

  ###-----------------------------------------------------###

  # 设定 filter table 的预设政策

  ###-----------------------------------------------------###

  iptables -P INPUT DROP

  iptables -P OUTPUT DROP

  iptables -P FORWARD DROP

  或预设全部接受∶

  ###-----------------------------------------------------###

  # 设定 filter table 的预设政策

  ###-----------------------------------------------------###

  iptables -P INPUT ACCEPT

  iptables -P OUTPUT ACCEPT

  iptables -P FORWARD ACCEPT

  各个规则链的预设政策可单独自主的设定,不必受其他链的影响。

  以下练习,若目标为 DROP,则 policy 请设为 ACCEPT;若目标为 ACCEPT,则 policy 请设为 DROP,如此方可看出效果。

  开放某一个介面

  作法如下∶

  iptables -A INPUT -i lo -j ACCEPT

  iptables -A OUTPUT -o lo -j ACCEPT

  注∶IPFW 或 Netfilter 的封包流向,local process 不会经过 FORWARD Chain,

  因此 lo 只在 INPUT 及 OUTPUT 二个 chain 作用。

  iptables -A INPUT -i eth1 -j ACCEPT

  iptables -A OUTPUT -o eth1 -j ACCEPT

  iptables -A FORWARD -i eth1 -j ACCEPT

  iptables -A FORWARD -o eth1 -j ACCEPT

  IP 伪装

  使内部网路的封包经过伪装之后,使用对外的 eth0 网卡当作代表号,对外连线。作法如下∶

  ###-----------------------------------------------------###

  # 启动内部对外转址

  ###-----------------------------------------------------###

  iptables -t nat -A POSTROUTING -o eth0 -s 172.16.0.0/16 -j SNAT --to-source $FW_IP

  上述指令意指∶把 172.16.0.0/16 这个网段,伪装成 $FW_IP 出去。

  虚拟主机

  利用转址、转 port 的方式,使外部网路的封包,能够到达内部网路中的伺服主机,俗称虚拟主机。这种方式可保护伺服主机大部份的 port 不被外界存取,只开放公开服务的通道(如 Web Server port 80),因此安全性甚高。

  作法如下∶

  ###-----------------------------------------------------###

  # 启动外部对内部转址

  ###-----------------------------------------------------###

  # 凡对 $FW_IP:80 连线者, 则转址至 172.16.255.2:80

  iptables -t nat -A PREROUTING -i eth0 -p tcp -d $FW_IP --dport 80 -j DNAT --to-destination 172.16.255.2:80

  开放内部主机能够 telnet 至外部的主机

  开放内部网路,能够 telnet 至外部主机。

  作法如下∶(预设 policy 为 DROP)

  ###-----------------------------------------------------###

  # open 外部主机 telnet port 23

  ###-----------------------------------------------------###

  iptables -A OUTPUT -o eth0 -p tcp -s $FW_IP --sport 1024:65535 -d any/0 --dport 23 -j ACCEPT

  iptables -A INPUT -i eth0 -p tcp ! --syn -s any/0 --sport 23 -d $FW_IP --dport 1024:65535 -j ACCEPT

文章整理:西部数码--专业提供域名注册虚拟主机服务
http://www.west263.com
以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢!