分享
 
 
 

linux下配置NAT服务

王朝system·作者佚名  2006-01-10
窄屏简体版  字體: |||超大  

网络地址转换(NAT)是用于将一个地址域(如:专用Intranet)映射到另一个地址域(如:Internet)的标准方法。NAT允许一个机构专用

Intranet中的主机透明地连接到公共域中的主机,无需内部主机拥有注册的(以及越来越缺乏的)Internet地址。

Internet工程任务组意识到目前地址空间(即所谓的IPv4)即将会耗尽已经有近十年时间了。尽管即将出现的IPv6被视作为解决Internet

不断发展的长期解决方案,但是在过去几年中还提出了其它一些短期解决方案。

我这里写的主要是如何配置一个NAT 服务器,关于NAT 的知识,大家不妨到网上google 一下,

有很多讲这个的咚咚。如果连这个也懒得去做的话,我就推荐你去中国IT 认证实验室linux 架站文

件系列中的一篇NATserver(http://www.chinaitlab.com/www/special/linux11.asp),你也可以在这里

(http://linux.vbird.idv.tw/)找到它的原文,不过是繁体的,看起来可能有些麻烦。在我看来这个作

者是一个很牛的人,却自称菜鸟,佩服!如果有时间的话,可以将他所写的一系列的文章都看看,

您会受益匪浅的!

好了下面开始讲如何配置NAT 服务器,我的环境是这样的:

服务器端:

1. 操作系统:Linux 2.6 核心

2. 双以太网卡:eth0 用于连接内部网络,内部IP 为:10.20.10.174

eth1 用于连接外部网络,外部IP 为:159.226.41.140

3. 使用iptables 配置NAT 服务

客户端:

1. Windows XP 客户端

2. Linux 客户端

配置步骤:

服务器端配置:

一. 首先将双网卡都驱动起来,并配置好其对应的IP 地址。

如果您的机器这部分已经配置好了的话,就可以直接进入第2 步,使用iptables 配置NAT 服务

了,否则请随着我一步步来。配置双网卡,最好一个个的来,而且最好两个网卡不是同一个型号的

芯片。具体为什么我也不清楚,有的人说不这样容易出错。这部分内容可以参考这两篇文章,讲述

的很是详细。安装网卡(http://www.chinaitlab.com/www/special/linux3.asp#3),在架设NAT 时安装

双网卡(http://www.chinaitlab.com/www/special/linux11.asp#9)

$ vi /etc/sysconfig/network-scripts/ifcfg-eth0

IPV6INIT=no

ONBOOT=yes

USERCTL=no

PEERDNS=yes

GATEWAY=

TYPE=Ethernet

DEVICE=eth0

BOOTPROTO=none

NETMASK=255.0.0.0

IPADDR=10.20.10.174

设定对内的网卡eth0 的参数,要了解各个参数的意义,请查阅/usr/share/doc/initscripts-*/sysconfig.txt

$ vi /etc/sysconfig/network-scripts/ifcfg-eth1

IPV6INIT=no

ONBOOT=yes

USERCTL=no

PEERDNS=yes

GATEWAY=159.226.41.190

TYPE=Ethernet

DEVICE=eth1

BOOTPROTO=none

NETMASK=255.255.255.192

IPADDR=159.226.41.140

设定对外的网卡eth1 的参数。

$ vi /etc/sysconfig/network

NETWORKING=yes

HOSTNAME=HPCOG-ASL

设定机器的网络信息,比如主机名,是否启动网络等。

$ vi /etc/resolv.conf

nameserver 159.226.39.1

nameserver 10.0.0.5

设定DNS 服务器

$ vi /etc/modprobe.conf

alias eth0 8139too

alias eth1 3c59x

设定eth0 为第一个网卡模块的别名,eth1 为第二块网卡的别名。

$ modprobe 8139too 3c59x && lsmod

启动两个网卡模块

$ /etc/rc.d/init.d/network restart

重新启动网络,应该也可以使用ifup eth0 eth1 这个命令来实现。

$ /sbin/ifconfig

查看网络配置信息

$ /sbin/route

查看路由信息。

二. 使用iptables 模块配置NAT 服务:

#!/bin/bash

#filename: nat.sh

##################Introduction####################

# 1. The file content if for configuring linux NAT server.

# 2. Execution:

# $ mkdir -p /usr/local/nat

# $ cp nat.sh /usr/local/nat/nat.sh

# $ chmod u+x /usr/local/nat/nat.sh

# $ /usr/local/nat/nat.sh

# or you can let it run automatically when machine reboots.

# $ vi /etc/rc.d/rc.local

# append "/usr/local/nat/nat.sh start" to it.

# 3. modified by lirui 2005/08/10

# 4. mail me: colin719@gmail.com

##################################################

IPTABLES='/sbin/iptables'

EXTERNAL='eth1'

EXTERNIP='159.226.41.141'

INTERNAL='eth0'

INTERNIP='10.20.10.0/24'

#reset the three default ipchains

$IPTABLES -P INPUT ACCEPT

$IPTABLES -P FORWARD ACCEPT

$IPTABLES -P OUTPUT ACCEPT

#reset the nat table

$IPTABLES -t nat -P PREROUTING ACCEPT

$IPTABLES -t nat -P POSTROUTING ACCEPT

$IPTABLES -t nat -P OUTPUT ACCEPT

#flush the ipchains and nat table

$IPTABLES -F

$IPTABLES -t nat -F

#delete non-default rules of ipchains and nat table

$IPTABLES -X

$IPTABLES -t nat -X

#reset zero

$IPTABLES -Z

$IPTABLES -t nat -Z

start(){

echo "Starting FireWall"

#load necessary modules

echo "Starting modprobe necessary modules for iptables"

for i in /lib/modules/`uname -r`/kernel/net/ipv4/netfilter/* ; do

t=`echo $i | sed 's/\..o$//g'`

mod=`basename $t`

/sbin/modprobe $mod

done

#enable ICMP packet (ping)

$IPTABLES -A INPUT -p icmp -j ACCEPT

#enable communication inside local domain

$IPTABLES -A INPUT -i $INTERNAL -s $INTERNIP -j ACCEPT

$IPTABLES -A OUTPUT -o $INTERNAL -d $INTERNIP -j ACCEPT

#enable ip masquerade

echo "1" >/proc/sys/net/ipv4/ip_forward

$IPTABLES -t nat -A POSTROUTING -o $EXTERNAL -s $INTERNIP -j MASQUERADE

# $IPTABLES -t nat -A POSTROUTING -s $IPDOMAIN -j SNAT --to $OUTIP

# $IPTABLES -t nat -A PREROUTING -d $EXTERNIP -p tcp --dport 21 -j DNAT --to $FTPIP

# $IPTABLES -t nat -A PREROUTING -d $EXTERNIP -p tcp --dport 80 -j DNAT --to $WEBIP

# Attention: there are no security!!!

}

stop(){

echo "Stopping firewall"

for i in /lib/modules/`uname -r`/kernel/net/ipv4/netfilter/* ; do

t=`echo $i |sed 's/\..o$//g'`

mod=`basename $t`

/sbin/modprobe -r $mod

done

#disable ipv4 packet forwarding

echo "0" >/proc/sys/net/ipv4/ip_forward

}

restart(){

stop

start

}

#see how we were called

case $1 in

start)

start

;;

stop)

stop

;;

restart)

restart

;;

*)

echo $"Usage:$0 { start | stop | restart }"

exit 1

esac

以上是我的一些简单的配置,对于复杂的配置,您可能还需要加入许多的内容哟.

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
推荐阅读
 
 
 
>>返回首頁<<
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有