欢迎来到天天文库
浏览记录
ID:20362612
大小:50.00 KB
页数:3页
时间:2018-10-12
《linux安全网关接口sgi的设计与实现》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库。
1、Linux安全网关接口SGI的设计与实现曲波1胡湜2(1南京晓庄学院信息技术学院)(2北京航空航天大学电子信息工程学院)摘要:文章阐述了Linux安全网关接口SGI的基本结构和实现方法,以及实现SGI涉及的Linux防火墙 内核接口模块、/proc文件系统内核接口等关键技术。关键字:安全网关接口、Linux防火墙、内核接口模块、防火墙钩子函数、/proc文件系统内核接口随着计算机网络技术的不断提高,计算机网络的应用也越来越普及,对计算机网络系统的安全管理也越来越重要。当前流行的各种操作系统都在计算机
2、安全管理方面提供了丰富的功能。Linux操作系统不仅在其内核中提供了丰富的防火墙功能,还以钩子函数的方式为用户提供了防火墙内核接口。用户根据Linux防火墙内核接口规范设计内核接口模块装入内存,就可实现用户自行设计的防火墙功能或其它网络访问控制功能。笔者利用Linux内核防火墙内核接口模块,实现了一个通用的安全网关接口(以下简称SGI)。SGI类似一个专用的防火墙,控制流经的网络IP数据包的转发。笔者在多个网络应用系统中利用该接口实现网络的安全访问控制,收到了很好的效果。1.安全网关接口SGI的基本
3、结构安全网关接口SGI的目标是实现一个通用的安全网关内核接口模块,实现对流经的IP数据包的转发控制。实现的方法是采用Linux的防火墙内核模块接口,通过防火墙钩子函数将自己挂接在系统的IP转发控制链中。SGI在内部维护一个Hash表,每一个表项包含一个代表着放行的IP地址。1.1SGI防火墙内核接口模块Linux防火墙Netfilter提供了一个抽象、通用化的框架,以IPv4为例,一共有5个防火墙钩子函数,分别为:NF_IP_PRE_ROUTING、NF_IP_LOCAL_IN、NF_IP_FORW
4、ARD、NF_IP_POST_ROUTING和NF_IP_LOCAL_OUT。数据报进入系统进行IP校验后,经过第一个钩子函数NF_IP_PRE_ROUTING进行处理;然后就进入路由代码,其决定该数据包需要转发还是发给本机;若该数据报是发给本机的,则该数据报经过钩子函数NF_IP_LOCAL_IN处理后传递给上层协议;若该数据报应该被转发则被NF_IP_FORWARD处理;经过转发的数据报经过最后一个钩子函数NF_IP_POST_ROUTING处理后,再传输到网络上。本地产生的数据报经过钩子函数N
5、F_IP_LOCAL_OUT3处理后,进行路由选择处理,然后经过NF_IP_POST_ROUTING处理后发送到网络上。内核模块可以对一个或多个这样的钩子函数进行注册挂接,并且在数据报经过这些钩子函数时被调用。SGI就是利用这种钩子函数实现内核接口模块并链接到防火墙内核接口钩子链上。1.2Hash表SGI防火墙内核接口模块的任务是确定对流经的IP数据包是否转发。所以,SGI需要维护一个数据表,该数据表中保存着需要转发的IP地址。每当SGI接口模块收到IP数据包后,立即在该数据表中查找该IP地址。若找
6、到则转发放行,找不到则丢弃该IP包。显然,数据表的结构是决定查找速度的关键。一方面,数据表的内容是由用户进程动态确定的,要随时变化。另一方面,查找的速度要快,不降低系统效率。尽管二叉检索树可以满足上述要求,但其实现代价较高,所以笔者采用Hash表方法实现。使用Hash表结构一方面可提高在IP转发过程中的查询速度,另一方面也可简化数据结构,节约内存资源。1.3/proc文件系统内核接口如前所述,Hash表的内容是由用户进程动态确定的,而SGI模块属于内核层。在Linux操作系统下,用户进程不能直接存取
7、系统内核数据,也不能直接调用内核函数。一般有两种方法可实现用户进程与内核进程的通信:一是使用设备文件,二是使用/proc文件系统。对于防火墙钩子函数来说,还可以通过套接字存取内核数据。笔者采用/proc文件系统实现用户进程与SGI接口模块的数据交换。由于/proc文件系统的主要作用是允许内核向应用进程报告它的状态,所以没有专门向内存输入数据而设置的机制。为能够写入/proc文件,在内核程序中要为相应的/proc文件提供专用的处理程序,即/proc文件系统内核接口。1.4 网络管理用户进程网络管理用户
8、进程的任务是通过SGI提供的/proc文件,向SGI内核模块设置所需转发的IP地址,包括插入、删除、查找等操作。采用标准的文件读写操作,按照SGI规定的数据格式与SGI内核模块交换数据。1.SGI的实现技术2.1Linux内核模块一个Linux内核模块至少包括两个函数:一个是初始化函数init_module(),在模块被插入到内核时调用;另一个是清除函数cleanup_module(),在模块从内核移走时调用。一般情况下,初始化函数或者在内存中注册一个处理程序,或者使
此文档下载收益归作者所有