http://www.veryarm.com/568.html
iptables或netfilter(网络过滤器)是一个工作于用户空间的防火墙应用软件,允许系统管理员可以调整设置X表(Xtables)提供相关的系统表格(目前主要位于iptables/netfilter)以及相关的“链”与“规则”,以管理网络数据包的流动与转送的动作。
Iptables是用户态提供的更改过滤规则的便捷工具,通过使用这个工具,可以方便的改变内核下netfilter的默认规则,也可以根据自己的需求添加自定的规则。
- iptables官网(Netfilter):http://www.netfilter.org/projects/iptables/index.html。
- iptables下载地址:ftp://ftp.netfilter.org/pub/iptables/。
移植步骤:
1 下载源码包
首先下载最新版的iptables,地址如上,下面以1.4.21版本为例,下载源码包为:
iptables-1.4.21.tar.bz2。
2 复制并解压源码包
将下载的源码包复制到Linux主机,然后进行解压:
$ mkdir ~/iptables
$ cp iptables-
1.4.
21.tar.bz2 ~/iperf
$
cd ~/iptables
$ tar jxvf iptables-
1.4.
21.tar.bz2
3 配置
$ mkdir install
$ cd iptables-1.4.21/
$ export PATH=$PATH:/usr/local/arm-2010q1/bin
$ ./configure --host=arm-none-linux-gnueabi --prefix=/home/veryarm/iptables/install --enable-static --disable-shared --with-ksource=/home/veryarm/board/kernel
其中,
- --host: 指定交叉编译工具,一般为arm-none-linux-gnueabi、arm-linux-gnueabihf、arm-linux等,具体要和目标板用的交叉编译工具对应。
- --prefix: 指定安装目录,编译后的文件会全部放在安装目录中。必须是绝对路径!
- --enable-static:使用静态编译。
- --disable-shared:禁止动态编译。
- --with-ksource:指定目标板的内核目录。如果不指定,可能会提示:/usr/sbin/iptables: line 1: syntax error: unexpected ")"错误。当然,因为这个是可选项,如果没有提示错误,也可以不加这一项。
4 编译安装
编译安装命令:
$ make -j4
$ make install
如果make的时候出现一些奇怪的错误,比如“iptables uses VFP register arguments ... does not”这些,可以使用 make clean & make distclean 先清理然后再make。
make install 完成之后,会在指定目录“/home/veryarm/iptables/install”下生成可执行文件,我们要用的是其中 /sbin 目录下的所有文件。
5 创建压缩包
将 /sbin 目录下的所有可执行文件压缩:
$ cd ../install/sbin
$ tar -cjvf iptables.tar.bz2 *
6 复制到目标板并执行
将上一步的压缩包由主机复制到目标板的 /usr/sbin 目录:
$ cp iptables.tar.bz2 ~
$ cd
$ tar -jxvf iptables.tar.bz2 -C /usr/sbin
7 测试
如果一下命令没有提示执行错误,说明移植成功:
$ iptables -L
$ iptables -A INPUT -t tcp --dport 80 -j ACCEPT
$ iptables -t nat -A PREROUTING -d 192.168.1.15 -p tcp -j DNAT --dport 9000 -- to 192.168.1.16:9000
$ iptables -t nat -L