荔园在线
荔园之美,在春之萌芽,在夏之绽放,在秋之收获,在冬之沉淀
[回到开始]
[上一篇][下一篇]
发信人: 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软件 网络书店