荔园在线

荔园之美,在春之萌芽,在夏之绽放,在秋之收获,在冬之沉淀

[回到开始] [上一篇][下一篇]


发信人: Chair (银发), 信区: Security
标  题: [转载] linux内核防火墙netfilter中的5个钩子
发信站: 荔园晨风BBS站 (Sun Feb  3 11:23:04 2002), 转信

【 以下文字转载自 Linux 讨论区 】
【 原文由 Chair 所发表 】

发信人: Chair (银发之轻装上阵), 信区: Linux
标  题: 名称:linux内核防火墙netfilter中的5个钩子
发信站: BBS 一网情深站 (Sun Feb  3 11:22:12 2002), 转信


netfilter是一种内核中用于扩展各种网络服务的结构化底层框架。netfilter的设

计思想是生成一个模块结构使之能够比较容易的扩展。新的特性加入到内核中并不

需要从新启动内核。这样,可以通过简单的构造一个内核模块来实现网络新特性的

扩展。给底层的网络特性扩展带来了极大的便利,使更多从事网络底层研发的开发

人员能够集中精力实现新的网络特性。
Netfilter有4大特性:
 1. 每一个协议定义"hooks"(钩子),IPv4定义了5个钩子,他们遍布协议栈中

包传输的整个过程。在每一个点上,协议将使用包和钩子号来调用netfilter框架


 2. 部分内核可注册后可以为每一个协议监听不同的钩子。因此,当包通过
netfilter框架时,它检查看是否有模块为协议和钩子注册;如果有,他们每一个

都有机会按顺序检验(也可能是更改)包,抛弃包,允许包通过,或者请求
netfilter为用户空间排队包。
 3. 排队了的包可以被收集送往用户空间;这些包是被异步的处理的。
 4.有非常良好的代码和文档。这一点对于一个拥有良好扩展性的开放式框架具

有极其深远的意义。离开了这一特性,netfilter结构将大为逊色甚至是难以操作

的。
 Netfilter整体结构如下图所示,netfilter仅仅只是协议栈中多个点上一系列钩

 Netfilter整体结构如下图所示,netfilter仅仅只是协议栈中多个点上一系列钩

子。IPv4的整个流程图如下

:包横穿netfilter系统示意图:
------ →[1]------ →[ROUTE]------ →[3]------ →[4]------ →
              |            ^
              |            |
              |            [ROUTE]
              v            |
              [2]           [5]
              |            ^
              |            |
              v            |


[1]:NF_IP_PRE_ROUTING:刚刚进入网络层的数据包通过此点(刚刚进行完版本号

,校验和等检测), 源地址转换在此点进行;
[2]:NF_IP_LOCAL_IN:经路由查找后,送往本机的通过此检查点,INPUT包过滤在此

点进行;
[3]:NF_IP_FORWARD:要转发的包通过此检测点,FORWORD包过滤在此点进行;
[4]:NF_IP_POST_ROUTING:所有马上便要通过网络设备出去的包通过此检测点,内

置的目的地址转换功能(包括地址伪装)在此点进行;
[5]:NF_IP_LOCAL_OUT:本机进程发出的包通过此检测点,OUTPUT包过滤在此点进

[5]:NF_IP_LOCAL_OUT:本机进程发出的包通过此检测点,OUTPUT包过滤在此点进

行。
内核模块可以被注册以监听这些钩子中的任意一个。接着当netfilter钩子被来自

域网络代码的核心调用,每一个在那一处注册了的模块就可以自由的操作处理包。

接下来模块可以告知netfilter做下列五件事中的一件:
  1.NF_ACCEPT:继续传递,保持和原来传输的一致;
  2.NF_DROP:丢弃包;不再继续传递;
  3.NF_STOLEN:接管包;不再继续传递;
  4.NF_QUERE:队列化包(通常是为用户空间处理做准备);
  5. NF_REPEAT:再次调用这一个钩子。
我们看include/linux/netfilter.h里面定义了

/* Largest hook number + 1 */
#define NF_MAX_HOOKS 8
也就是说Netfilter最多可以支持8个hook.为了扩展方便,Netfilter也提供了很方

便的nf_register_hook函数用来加入我们自己的代码。int
nf_register_hook(struct nf_hook_ops *reg)
下面是nf_hook_ops的结构
struct nf_hook_ops
{
struct list_head list;

/* User fills in from here down. */
我们看include/linux/netfilter.h里面定义了
nf_hookfn *hook;
int pf;
int hooknum;
/* Hooks are ordered in ascending priority. */
int priority;
};


--
※ 来源:.BBS 一网情深站 bbs.szptt.net.cn.[FROM: 202.104.119.98]


--


           半张口 ... 深呼吸 ... 浅浅笑 ... 轻叹 ...



※ 来源:·荔园晨风BBS站 bbs.szu.edu.cn·[FROM: 203.93.19.1]
--
※ 转载:·荔园晨风BBS站 bbs.szu.edu.cn·[FROM: 203.93.19.1]


[回到开始] [上一篇][下一篇]

荔园在线首页 友情链接:深圳大学 深大招生 荔园晨风BBS S-Term软件 网络书店