庞大资源库的计算机教程网站!
设为首页
加入收藏
总编信箱
投稿或申请专栏请先 [登 陆]
首页 操作系统 程序设计 图形图像 媒体动画 机械电子 WEB开发 数 据 库 办公系列 路由技术 网络原理 网络应用
认证考试 安全技术
首页>操作系统>Linux>系统安全>正文
资料搜索
Google搜索
Google
返回上级列表

推荐文章

快速保存网页中所有图片的方法
Windows中让光驱巧妙“隐身”技
防范非法用户入侵Win 2000/XP系
两款比较典型的ASP木马防范方法
有关表格边框的css语法整理
Windows XP中可以被禁用的服务
SQL Server导出导入数据方法
Javascript所有对象的属性的获
网页(HTML)中的特殊字符
与篮球共舞,尽显模式本色
QQ病毒的手工清除方法
Photoshop为极品美女打造性感睫
天衣无缝:IIS与PHP水火也相容
SQL Server存储过程编写和优化

基于Linux的路由器和防火墙配置

 作者:何立强    日期:2005-4-13
字号选择〖 〗/ 双击滚屏 单击停止   
   随着Internet应用的日益普及,免费网络操作系统Linux受到越来越多的网络爱好者 的关注。通过简单的安装,人们就可以获得Linux提供的多项网络服务,诸如域名服务、电 子邮件、匿名FTP服务等。同时,它还提供了图形工作站所具有的Xwindows系统。可以说 ,Linux已经具备了网络服务器的所有功能。在此,笔者想结合自己的工作经验,谈谈Linu x在另一方面的用途,即将Linux作为路由器连接两个不同的网段,并在其上配置防火墙,以 实现网络的存取访问控制和流量统计的功能。


   要想使一台装有Linux的PC具有路由器的功能,首先要进行硬件配置。名为Router的PC上装有Linux系统,并配有两块网卡,每块网卡连接一个不同的网段,该机作 为路由器在两个网段间转发IP数据包。为了防止两块网卡的中断发生冲突,需要网卡驱动程序将中断分别设为不同值。笔者在实践时将其中断号和I/O地址分别设置为:3,0x300H 和4,0x320H。

   硬件配置完毕,还需要在软件上做相应的配置。在通常的安装模式下,Linux系统不具 备路由器的功能,因此,必须重新安装Linux内核。以Slackware版的Linux为例,其重新配 置内核的过程为:

   1. #cd/usr/src/linux
   /*进入Linux的源代码目标*/

   2. #make config
   /*进行编译选项的配置*/

   在该步中,系统会提供编译过程中的一些选项,供用户根据自己的实际情况进行选择 。对于无法确定的选项,用户可选择系统缺省值。在网络部分编译的询问中,会出现如下 的提示:

   network firewall[y/n/N]?
   /*内核是否支持防火墙*/
   ……
   TCP/IP networking[n/y/Y]?
   /*主机是否连接TCP/IP网络*/
   IP: forwarding/gatewaying [n/y/Y]?
   /*主机是否转发数据库或作为网关*/
   ……
   IP:firewalling[y/n/N]?
   /*是否在TCP/IP网络内设置防火墙*/
   IP:firewall packet logging[y/n/N]?
   /*是否在防火墙上登记数据包*/
   ……
   IP:accounting[y/n/N]?
   /*是否对数据包计帐*/
   IP:optimize as router not host[y/n/N]?
   /*是否将主机设置为路由器*/
   ……
   IP:multicats routig [y/n/N]?
   /*路由器是否向外广播路由信息*/

   因为我们要将此主机配置为路由器,并在其上设置防火墙,故对这些选项统一选"y"。

   3.#make dep
   /*根据编译选项做编译前的准备工作*/

   4.#make zlmage
   /*开始编译内核并命名编译后的内核文件名为zlmage*/

   编译后的内核存于"/usr/src/linux/arch/i386/boot"目录。在系统原内核备份后, 用户可将该文件拷贝到根目录下,并改名为"vmlinuz",运行"lilo",使其在下次启动时生 效。

   重构内核后,需对两块网卡的TCP/IP部分进行设置,使其能有效地连接两个不同的网 段,并能在两个网段进行IP数据包的转发。设置步骤为:

   1.对于NE2000兼容的网卡,修改"/etc/rc.d/rc.modules"文件;

   /sbin/modprobe ne io=0x300,0x320
   /*识别两块网卡*/

   2.修改"/etc/rc.d/rc.inetl"文件,设置两网卡的IP地址、掩码及到两网卡的路由

   信息;

   IPADDR="202.207.0.27"

   NETWORK="202.207.0.0"

   BROADCAST="202.207.0.255"

   IPADDR1="202.207.7.2"

   NETWORK1="202.207.7.0"

   BROADCAST1="202.207.7.255"

   NETMASK="255.255.255.0"

   /sbin/ifconfig eth0 ${IPADDR} broadcast${BROADCAST} netmask${NETMASK}

   /sbin/ifconfig eth1 ${IPADDR1} broadcast${BROADCAST1} netmask${NETMASK}

   /sbin/route add-net ${NETWORK} netmask${NETMASK} eth0

   /sbin/route add-net ${NETWORK1} netmask ${NETMASK} eth1

   3.修改"/etc/rc.d/rc.inet2"文件,打开关于"Routed Server"的注释,使其可以与其它路由器交换路由信息,并转发IP数据包。

   ## Start the Routed server

   if[-f ${NET}/routed];then

   echo -n"routed"

   ${NET}/routed -g -s

   /*启动程序*/

   fi

   4.在"/etc/lilo.conf"文件中增加一行,使其在启动时识别第二块网卡。

   append="ether=0,0x320,ethl"

   完成上面的设置后,应重新启动计算机,系统会识别到两块网卡,并按照"/etc/rc.d/ rc.intel"文件中的说明对网卡的IP地址、掩码进行设置。启动完成后,以超级用户root 的身份进入系统,键入下面的命令即可看到关于网卡和路由的信息。

   #ifconfig /*显示网卡的详细信息*/

   #route

   /*显示系统的路由表*/

   笔者曾将学生机房局域网内的PC通过Linux路由器与校园网相接,并进一步通过校园 网进入Internet。此外,笔者又在Linux路由器上配置了防火墙。实践证明,防火墙有效地 控制住了学生对非法IP地址的访问,并成功地记录下每个IP地址的网络流量,为计费和网 管提供了依据。Linux的防火墙配置可以通过简单的命令逐条进行,也可编写shell程序放 到系统的启动目录下自动执行。其命令格式非常简单,现举例如下:

   #ipfwadm -A

   /*对通过路由器的所有数据包进行计帐*/

   #ipfwadm -I -a accept -S 162.105.0.0/16

   /*接受来自162.105.0.0网络的所有数据包*/

   #ipfwadm -I -a deny -S 159.226.0.0/16

   /*丢掉来自159.226.0.0网络的所有数据包/

   #ipfwadm -O -a reject -S 210.32.0.0/12

   /*丢掉发往210.32.0.0网络的所有数据包,并发送拒绝信息包给请求者*/

   读者可根据实际需要进行防火墙的配置,以达到期望的效果。
上一篇:加固Linux服务器    下一篇:解读防火墙记录  
[发送给好友]  [关闭窗口]  [返回顶部]   转载请注明来源:www.it00.com   
特别声明: 本站除部分特别声明禁止转载的专稿外的其他文章可以自由转载,但请务必注明出处和原始作者。文章版权归文章原始作者所有。对于被本站转载文章的个人和网站,我们表示深深的谢意。如果本站转载的文章有版权问题请联系编辑人员,我们尽快予以更正。
责任编辑: 原点 投稿作者: 何立强
信息来源: 网络 录入时间: 2005-4-13
关于我们 - 广告服务 - 版权申明 - 网站地图 - 联系方式 - 总编信箱 - 会员投稿