Username: Password:

Linux 2.4内核中新增功能指南
来源: 作者: 发布时间:2007-12-25 07:34:49

 一 本文目的

  本文主要是探讨 Linux 2.4 内核中的iptables 的各种新增功能和使用方法,怎样有效地使用这些新增的功能配置企业的防火墙规则,举例说明了新增功能在企业中的应用。

  二 操作环境

  Redhat Linux 7.1自带的模块化内核,专线连接互连网,两块网卡的防火墙,内部网段为10.0.0.0/255.255.255.0, 防火墙外部网卡接口地址为1.2.3.4。

  三 iptables和ipchains的不同之处

  1. 内置规则的重新定义,简单化规则管理Linux 内核中内置的INPUT,OUTPUT,FORWARD规则在新的iptables中,任何一个包仅仅只在这三个规则中的任何一个上应用,或被INPUT规则击中,或被FORWARD规则或OUTPUT规则击中,不象在ipchains中任何一个包假如是穿过这台防火墙总要同时击中三个规则。

  为了说明这种改变,请看下面的代码。

  Incoming / Outgoing
  -->[Routing ]--->|FORWARD|------->
  [Decision] _____/ ^
  | |
  v ____
  ___ /
  / Linux防火墙 |OUTPUT|
  |INPUT| ____/
  ___/ ^
  | |
  ----> Local Process ----

  a. 首先,当一个包进来的时候,也就是从以太网卡进入防火墙,内核首先根据路由表决定包的目标。
  b. 假如目标主机就是本机,则如上图直接进入INPUT链,再由本地正在等待该包的进程接收,结束。
  c. 否则,假如从以太网卡进来的包目标不是本机,再看是否内核允许转发包(可用echo 1> /proc/sys/net/ipv4/ip_forward 打开转发功能)假如不允许转发,则包被DROP掉,假如允许转发,则送出本机,结束。这当中决不经过INPUT或OUTPUT链,因为路由后的目标不是本机,只被转发规则应用
  d. 最后,该linux防火墙主机本身能够产生包,这种包只经过OUTPUT链出去。

  注意: echo 1 > /proc/sys/net/ipv4/ip_forward 和 FORWARD 链的区分

  前者的意思是是否打开内核的转发功能,后者是转发链规则只有内核打开转发功能,一个包才可能被送到转发链上去逐项检查规则。

  假如一台防火墙没有打开前者的IP转发功能,则根防火墙相连的两边的网络是完全隔离的,假如是一端连到internet上,则只能通过代理防问internet,不可能通过IP伪装的方式防问。

  这样,任何一个包只可能应用INPUT/OUTPUT/FORWARD中的一个规则,这种巨大的改进同时也简单化了防火墙规则管理。


喜欢本文,那就收藏到:

    Del.icio.us Google书签 Digg Live Bookmark Technorati Furl Yahoo书签 Facebook 百度搜藏 新浪ViVi 365Key网摘 天极网摘 和讯网摘 博拉网 POCO网摘 添加到饭否 QQ书签 Digbuzz我挖网
相关评论  我也要评论
还没有关于此文章的相关评论!
  • 昵称: (为空则显示guest)
  • 评论分数: ★ ★ ★★★ ★★★★ ★★★★★
  • 评论内容:(不能超过250字,需审核后才会公布,请自觉遵守互联网相关政策法规。
  • 导航
    赞助商
    文章类别
    订阅